zoukankan      html  css  js  c++  java
  • 清空StringBuilder的三种方法及效率

    清空StringBuilder的三种方法及效率  

    大家知道对于字符串频繁拼接是使用stringbuilder.Append方法比使用string+=方法效率高很多,但有时需要清空stringbuilder时却不知道怎么清空,因为它没有clear或empty的方法。那用什么方法呢?在网上搜了一下大概一下三种方法。
    1、Remove
    例:
                StringBuilder val = new StringBuilder();
                val.Append("....");
                val.Remove(0,val.Length);//清空
    2、Replace
                StringBuilder val = new StringBuilder();
                val.Append("....");
                val.Replace(val.ToString(), "");//清空
    3、Length 
                StringBuilder val = new StringBuilder();
                val.Append("....");
                val.Length = 0;//清空
    对于这三种方法的效率简单做了一下测试,测了三次求的平均值
     测试方法:
                DateTime dt = DateTime.Now; 
                const int testNum = 1000000;
                StringBuilder strbuilder = new StringBuilder();
                for (int i = 0; i < testNum; i++)
                {
                    strbuilder.Append("test");
                    strbuilder.Remove(0,strbuilder.Length);
                }
                Console.WriteLine("Rsemove:"+(DateTime.Now - dt).Ticks);
    第一种用时间:366687
    第二种用时间:1186734
    第三种用时间:180010
    可见还是使用length方法比较效率。
    此次测试是本人的简单测试,如有不同意见请留言,共同学习探讨!
  • 相关阅读:
    题解 UVA10213 【How Many Pieces of Land ?】
    NOIP 2018 游记
    POJ 1821 Fence(单调队列优化DP)
    HDU 2196 Computer(经典树形DP)
    POJ 2228 Naptime(DP+环形处理)
    POJ 1742 Coins(多重背包?)
    POJ 2311 Cutting Game(SG函数)
    BZOJ 2560(子集DP+容斥原理)
    HDU2841 Visible Trees(容斥原理)
    HDU 1796 How many integers can you find(容斥原理)
  • 原文地址:https://www.cnblogs.com/SpiderKevin/p/3891425.html
Copyright © 2011-2022 走看看