string与StringBuilder的性能对比

关于stringStringBuilder的区别,这里就不做详细的说明了,毕竟网上一大堆这方面的文章。这里我就直接贴出一个新能测试的对比,大家一看就知道它们之间的区别。

首先,还是简单解释一下stringStringBuilder

string对象是不可改变的。每次使用 System.String类中的方法之一时,都会在内存中创建一个新的字符串对象,这个时候就需要在内存中为该新对象分配新的空间。在对字符串重复执行复制的时候(例如: string a = "1"; a+=1;),与创建新的 String对象对比,系统开销会非常大。

StringBuilder对象是动态对象,长度可变。当修改 StringBuilder时,它首先会默认一个空间,当长度达到这个容量时,将自动分配新的空间且容量翻倍,所以它是一个可自动变法的对象。

废话就不说了,直接贴出相关性能测试代码:

StringBuilder测试代码

protected void Button3_Click(object sender, EventArgs e)
    {
        long startData = DateTime.Now.Ticks;
        StringBuilder sb = new StringBuilder();
        int count = int.Parse(TextBox2.Text);
        for (int i = 0; i < count; i++)
        {
            sb.Append("测试写入日志" + i + "," + TextBox1.Text + "\r\t");
        }
        new WriteLog().WriteLog_1("StringBuilder测试写入日志", sb.ToString());
        long endData = DateTime.Now.Ticks;
        this.TextBox5.Text = TimeSpan.FromTicks((endData - startData)).TotalMilliseconds + "";
    }

StringBuilder测试执行结果

 

string测试代码

 protected void Button4_Click(object sender, EventArgs e)
    {
        long startData = DateTime.Now.Ticks;
        string sb = "";
        int count = int.Parse(TextBox2.Text);
        for (int i = 0; i < count; i++)
        {
            sb += "测试写入日志" + i + "," + TextBox1.Text + "\r\t";
        }
        new WriteLog().WriteLog_1("String测试写入日志", sb);
        long endData = DateTime.Now.Ticks;
        this.TextBox5.Text = TimeSpan.FromTicks((endData - startData)).TotalMilliseconds + "";
    }

string测试执行结果

 

一看这结果,大家就应该明白了吧... ...

还不明白你就out了... ...

你可能感兴趣的:(String,object,测试,button,textbox)