qq_43050721 2019-01-04 20:09 采纳率: 100%
浏览 301
已采纳

例如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条回答 默认 最新

  • threenewbee 2019-01-04 20:14
    关注

    你的程序有2个问题

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

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥15 BC260Y用MQTT向阿里云发布主题消息一直错误
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 Centos / PETGEM
  • ¥15 划分vlan后不通了
  • ¥20 用雷电模拟器安装百达屋apk一直闪退
  • ¥15 算能科技20240506咨询(拒绝大模型回答)