例如vs这个编译器,是不是在执行完所有的代码之后再执行里面的输出语句?

我用c#写了两个stopwatch测试一下stringbuilder和string循环写入的速度差异。

代码是:

        int n = 500;
        Stopwatch time = new Stopwatch();
        time.Start();
        StringBuilder xx = new StringBuilder();
        while (n > 0)
        {
            n--;
            xx.Append(n);
            Console.WriteLine(xx);
        }
        xx.Clear();
        time.Stop();
        Console.WriteLine("stringbuilder:" + time.Elapsed);
        time.Start();
        string a = "";
        while (n > 0)
        {
            n--;
            a = a + Convert.ToString(n);
            Console.WriteLine(a);
        }
        time.Stop();
        Console.WriteLine("string:" + time.Elapsed);
        Console.ReadKey();

但是在控制台的输出结果一看,是先把两个循环的输出完了再把结果直接打印出来。
图片说明

1个回答

你的程序有2个问题

第一,
n = 500; //加上
while (n > 0)
{
n--;
a = a + Convert.ToString(n);
Console.WriteLine(a);
}
没有这一行,你调试下,n是0,所以第二个循环根本没有跑,所以输出了stringbuilder后直接输出了string

另一个问题是,你在循环里输出字符串,这个会浪费很多时间,所以你要比较string加法和stringbuilder,最好不要在循环里每次输出一个数字。

caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 回复qq_43050721: 问题如果解决,请点下我回答左上角的采纳,谢谢
大约一年之前 回复
qq_43050721
qq_43050721 我学得太浅薄了,光以为循环内的值不会影响到循环外,但是现在这个变量是在外部已经初始化了。居然问出了这么愚蠢的问题。。。谢谢!!
大约一年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问

相似问题

0
用Xcode编译,有scanf的代码,二次执行后无法正常输入?
0
unity 如何自定义编译器窗口,可以在编译器窗口中编写脚本并且运行?
0
vs编译器优化疑问,为什么会优化成这样?
0
Qt: 以前一直使用的是Qt的mingw编译器,换了个编译器报错,找不到Q_OBJEC 这是为什么啊?
1
代码在经历过编译之后,提示没有找到资源文件
0
怎么在wins系统上交叉编译生成linux(不是嵌入式平台,想找一个gcc交叉编译器)文件?
1
windows下用thrift预构建编译器生成的java代码有语法错误
1
为何HotSpot虚拟机要使用解释器和编译器并存的架构?
3
在用VS2010时,为什么这个代码会编译出错?
2
VS2010编译后的程序执行时无反应
0
flutter链式调用,编译器是如何推导出,匿名函数的参数是上个异步任务的执行结果
2
让C语言编译器,输出一个字符串,但是代码出错
1
单独输出窗口的windows代码 为什么在我的编译器运行 后面还是有控制台
2
这是一个关于C语言编译器5.4的问题
1
怎么让编译器前置,视频在背景播放?
1
这个程序我自己在编译器上通过了,但是OJ上一直runtime error。各位大神可否帮我看看代码有什么问题吗?
3
这是一个关于C++编译器的相关问题
0
C语言编译器由哪三部分组成,请简述每个部分的作用和名称?
1
C语言代码编写除了代码编辑、编译运行,还有什么步骤,3个步骤的顺序是什么
0
有人知道怎么用Intel Parallel Studio XE编译安卓代码吗?