網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序制作、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了鐘山免費建站歡迎大家使用!
1. C# 有兩種類型的常量:編譯時常量和運行時常量。
2.盡量使用運行時常量,而不是編譯時常量。
////// 編譯時常量 /// public const int Num = 100; ////// 運行時常量 /// public static readonly int Year = 2017;
3.編譯時常量只能用于數(shù)字和字符串,運行時常量也是一種常量,因為在構(gòu)造函數(shù)執(zhí)行后它不能被再次修改。
4.const 比 readonly 效率高,但靈活性低。
1.as 比強轉(zhuǎn)更加高效、安全。
2.as 操作符不能配合值類型使用,因為值類型永遠不可能為 null。
1.應(yīng)該為類型提供一個合適的 ToString() 版本,否則使用者會根據(jù)類的一些屬性來自行構(gòu)造并用于顯示。
2.object 默認提供的 ToString() 方法會返回類型的完整名稱,意義不大。如:System.Drawing.Rect。
3.重寫所有類型的 ToString(),可以簡單明了的顯示對象的摘要信息。
1.系統(tǒng)提供 4 種函數(shù)判斷兩個對象是否“相等”。
2.對于前兩種方法,我們永遠不要重新定義,我們通常要重寫 Equals 方法。
3.重寫 Equals 的類型也要實現(xiàn) IEquatable
4.引用同一個 DataRow,會認為相等,如果想比較內(nèi)容的話,而不是引用地址,那么就應(yīng)該重寫 Equals() 實例方法。
5.Equals() 實例方法的重寫原則:對于所有的值類型,都應(yīng)該重寫 Equals() 方法,對于引用類型,如果不能滿足需要時才去重寫該方法。重寫該方法的同時也需要重寫 GetHashCode() 方法。
6.operator == ():只要創(chuàng)建的是值類型,都必須重新定義 operator == (),因為系統(tǒng)默認是通過反射來比較兩個值是否相等,效率過低。
1.對于我們實現(xiàn)的大多數(shù)類型來說,避免實現(xiàn) GetHashCode()。
2.GetHashCode() 的重載版本必須遵循以下三條原則:
(1)如果兩個對象相等(由 operator == 定義),那么它們必須生成相同的散列碼。
(2)對于任何一個對象 A,A.GetHashCode() 必須保持不變。
(3)對于所有的輸入,散列函數(shù)應(yīng)該在所有整數(shù)中按照隨機分布生成散列碼。
示例:
//1.使用循環(huán) var foo = new int[100]; for (int i = 0; i < 100; i++) { foo[i] = i * i; } //使用查詢語法 var foo2 = (from n in Enumerable.Range(0, 100) select n * n).ToArray();
1.有些方法語法沒有對應(yīng)的查詢語法,如 Take、TaskWhile、Skip、SkipWhile、Min、Max 等,就需要使用方法語法。
1.對于程序集的第一次發(fā)布,可以隨意使用可選參數(shù)和命名參數(shù)。而在進行后續(xù)發(fā)布時,必須為額外的參數(shù)創(chuàng)建重載。這樣才能保證現(xiàn)在的程序仍能正常運行。此外,在任何的后續(xù)發(fā)布中,都要避免修改參數(shù)的名稱,因為參數(shù)名稱已經(jīng)成為公有接口的一部分。
1.我們最好盡可能地編寫出最清晰的代碼,將優(yōu)化工作交給 JIT 完成。一個常見的錯誤優(yōu)化是,我們將大量的邏輯放在一個函數(shù)中,以為這樣可以減少額外的方法調(diào)用開銷。
public string Test(bool isTrue) { var sb = new StringBuilder(); if (isTrue) { sb.AppendLine("A"); sb.AppendLine("B"); sb.AppendLine("C"); } else { sb.AppendLine("E"); sb.AppendLine("F"); sb.AppendLine("G"); } return sb.ToString(); }
在第一次調(diào)用 Test 方法時, if-else 的兩個分支都被 JIT 編譯,而實際上只需要編譯其中一個,修改后:
public string Test2(bool isTrue) { var sb = new StringBuilder(); if (isTrue) { return Method1(); } else { return Method2(); } }
現(xiàn)在進行了方法拆分,這兩個方法就可以根據(jù)需要進行 JIT 編譯,而不必第一次進行全部編譯。
2.可以將 if-else 分支中有超過幾十條的語句,或者某個分支專門用來處理程序發(fā)生的錯誤,或者 switch 語句中的每個 case 中的代碼進行選擇性的提取。
3.短小精悍的方法(一般包含較少的局部變量)會讓 JIT 更容易地進行寄存器選擇工作,即選擇哪些局部變量放在寄存器中,而不是棧上。
4.盡量編寫短小精悍的方法。