C# 性能優(yōu)化細(xì)節(jié)
1、使用string.Empty給一個(gè)空字符串變量賦初始值
String.Empty是一個(gè)指代,而””是具體的實(shí)現(xiàn)string filter=“”;//不建議 string filter=string.Empty; //建議2、使用str.Length == 0做空串比較
最快的方法:if (str.Length == 0)其次:if (str == String.Empty)或 if (str == "")3、避免不必要的字符串ToUpper、ToLower類(lèi)操作
ToUpper、ToLower這類(lèi)方法均會(huì)重新生成字符串對(duì)String.Compare可實(shí)現(xiàn)忽略字符串大小寫(xiě)//不推薦的寫(xiě)法if(s1.ToUpper()==s2.ToUpper()) …;//推薦的寫(xiě)法if(String.Compare( s1, s2, true ) == 0) …;4、巧用StringBuilder進(jìn)行字符串拼接操作
如果要構(gòu)造一個(gè)較長(zhǎng)的字符串,尤其是拼接超過(guò)10次時(shí)(經(jīng)驗(yàn)值),應(yīng)使用StringBuilder做字符串拼接操作。<PRe name="code" class="csharp">//不建議:string s = null;for (int i = 0; i < 10000; i++){ s += i;}//建議:StringBuilder sb = new StringBuilder();for (int i = 0; i < 10000; i++){ sb.Append(i);}string t = sb.ToString();</pre><br><img src="http://img.blog.csdn.net/20151107160714247?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">5、創(chuàng)建StringBuilder應(yīng)指定初始大小
默認(rèn)的初始大小為16,一旦超過(guò)即需要Resize一次并增加GC壓力。建議根據(jù)經(jīng)驗(yàn)值為其指定初始大小。StringBuilder sb = new StringBuilder();for (int i = 0; i < 10; i++){ sb.Append(i);}string s = sb.ToString();//建議修改為StringBuilder sb = new StringBuilder(256);for (int i = 0; i < 10; i++){ sb.Append(i);}string s = sb.ToString();6、避免濫用StringBuilder
類(lèi)似str1+str2+str3+str4的字符串拼接操作會(huì)被編譯為 String.Concat(str1,str2,str3, str4),效率反而高于StringBuilder。String.Concat會(huì)一次性確定字符串長(zhǎng)度, StringBuilder需要做Resize,適用于多次生成string對(duì)象的情況。7、通過(guò)直接設(shè)置.Length=0來(lái)初始化StringBuilder
根據(jù)實(shí)驗(yàn)結(jié)果,多次使用同一StringBuilder對(duì)象時(shí),通過(guò)直接設(shè)置.Length=0來(lái)初始化速度最快。StringBuiler sb = new StringBuilder(256); ......sb.Remove(0, sb.Length); //不建議sb.Length = 0; //建議8、不要使用.Length=0來(lái)釋放StringBuilder占用的內(nèi)存
static void test(){ StringBuilder sb = new StringBuilder(256); for (int i = 0; i < 100; i++) { sb.Append(i); } string t = sb.ToString(); ……//其他不使用變量sb的代碼段 sb.Length = 0; //去掉該句手工清空sb代碼,會(huì)更早釋放內(nèi)存}9、string的IndexOf和Contains性能測(cè)試
通過(guò)測(cè)試證明 Contains 速度比IndexOf快很多。
10、C#中“Equals”與“==”的速度比較
下面列出5次測(cè)試結(jié)果的對(duì)比:
true測(cè)試最快方式 | true測(cè)試最快方式與第二名的差距 | false測(cè)試最快方式 | false測(cè)試最快方式與第二名的差距 | |
測(cè)試1 | "value" == string | 0.046 s | "value".Equals(string) | 0.016 s |
測(cè)試2 | "value" == string | 0.219 s | "value".Equals(string) | 0.036 s |
測(cè)試3 | string == "value" | 0.015 s | "value".Equals(string) | 0.001 s |
測(cè)試4 | string == "value" | 0.068 s | string.Equals("value") | 0.021 s |
測(cè)試5 | string == "value" | 0.066 s | "value".Equals(string) | 0.001 s |
true測(cè)試:"value" == string領(lǐng)先總時(shí)間為0.265秒,string == "value"領(lǐng)先總時(shí)間為0.149秒;
false測(cè)試:"value".Equals(string)領(lǐng)先總時(shí)間為0.054秒,string.Equals("value")領(lǐng)先總時(shí)間為0.021秒。
現(xiàn)在我們暫時(shí)可以得到的結(jié)論是:true判斷時(shí),用"value" == string是最快的;false判斷時(shí),用"value".Equals(string)是最快的。
也就是說(shuō):一個(gè)判斷true發(fā)生的情況多些時(shí),用"value" == string;false發(fā)生的情況多些時(shí),用"value".Equals(string)。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注