4、TryParse比Parse好
下面的TryParse的方法定義
public static bool TryParse(string s, out Double result);
Parse如果轉換失敗會報錯,但是TryParse有回傳值可以判斷是否轉換成功
string str1 = "abfc12"; if(double.TryParse(str1, out double dou1)) { Console.WriteLine(dou1); }
如果有需要值類型為空,我們可能會使用一個特殊值例如-1 來判斷int是不是為空,最好改成int?類型,判斷是否為null
Nullable<int> i1 = 4; // i2 和 i1 的定义方式一样 只是写法不同 下面的int?是一个语法糖 int? i2 = null; int i3 = 0; //int类型可以默认转为int?类型 i2 = i3; //int?类型需要强转成int类型,如果是null则变为0 i3 = (int)i2;
簡單區別就是const效率高,readonly靈活性高
const是編譯器常數,readonly是運行時常數
const int constNum = 1; public string name; public int age; public FirstType() { name = "aa"; age = constNum; age = 1; } //使用以上代码测试,下面的编译成的IL代码 IL_0000: ldarg.0 IL_0001: call instance void [mscorlib]System.Object::.ctor() IL_0006: nop IL_0007: nop IL_0008: ldarg.0 IL_0009: ldstr "aa" IL_000e: stfld string CSharpSuggest.FirstType::name IL_0013: ldarg.0 IL_0014: ldc.i4.1 IL_0015: stfld int32 CSharpSuggest.FirstType::age IL_001a: ldarg.0 IL_001b: ldc.i4.1 IL_001c: stfld int32 CSharpSuggest.FirstType::age IL_0021: ret
可以看出13,14,15 和1a,1b,1c是一樣的,所以age = constNum;和age = 1;是等效的所以效率最高
const只能修飾基元類型、枚舉型別或字串型,readonly沒有限制
const自然是static 不能再增加static
readonly的值一般在構造函數裡面賦值,每個類別的物件都可以有不同的readonly值,但由於const是靜態的,所以所有的類別該值都是一樣的
##書中有上面這句話,我一直有個疑問,在類內賦值和構造函數賦值有什麼區別,網上沒搜到,反編譯出來的IL代碼僅僅是變量定義的順序區別,如果有知道請告知。 。 7、將0作為枚舉的預設值我理解的是如非必要,不要更改枚舉的數值,可能會出現意料之外的結果8、避免提供枚舉類型元素顯示的值原因同上相關文章:##C#學習記錄:撰寫高品質程式碼改善整理建議1-3C#學習記錄:撰寫高品質程式碼改善整理建議9-15以上是C#學習記錄:撰寫高品質程式碼改善整理建議4-8的詳細內容。更多資訊請關注PHP中文網其他相關文章!