qq_43050721
qq_43050721
2019-01-04 20:09

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

  • c#
  • visual studio

我用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条回答