dynamic是FrameWork4.0的新特性。dynamic的出現讓C#具備了弱語言類型的特性。編譯器在編譯的時候再也不對類型進行檢查,編譯期默認dynamic對象支持你想要的任何特性。好比,即便你對GetDynamicObject方法返回的對象一無所知,你也能夠像以下那樣進行代碼的調用,編譯器不會報錯:
Console.WriteLine(dynamicObject.Name);
Console.WriteLine(dynamicObject.SampleMethod());
實際上,var和dynamic徹底是兩個概念,根本不該該放在一塊兒作比較。var其實是編譯期拋給咱們的「語法糖」,一旦被編譯,編譯期會自動匹配var 變量的實際類型,並用實際類型來替換該變量的申明,這看上去就好像咱們在編碼的時候是用實際類型進行申明的。而dynamic被編譯後,實際是一個object類型,只不過編譯器會對dynamic類型進行特殊處理,讓它在編譯期間不進行任何的類型檢查,而是將類型檢查放到了運行期。
foreach不支持循環時增刪操做
若是在foreach中增/刪某一元素,則會拋出異常。
緣由:foreach循環使用了迭代器進行集合的遍歷,它在FCL提供的迭代器內部維護了一個對集合版本的控制。
集合版本:簡單來講就是一個整型變量,任何對集合的增刪操做都會使版本號+1。
foreach循環會調用MoveNext方法來便利元素,MoveNext方法內部會進行版本號的檢測,一旦版本號變更,就會拋異常。
必要時將再也不使用的對象引用賦值爲null
delegate與event
public delegate void ActionCall(); public event ActionCall call; //委託能夠賦值(=)和綁定(+= -=),事件只能綁定(+= -=) //事件在本類能夠調用,其餘類中不能調用;
拓展方法:不改變原類,給類添加方法
public class Test { public void Action() { } } //擴展方法必須在靜態類中,擴展方法必須是靜態的 public static class TestExtension { public static void ActionExtension(this Test t) //第一個參數必須是要擴展的類型,且必須加上了this關鍵字 { }
public static void ActionExtension1(this Test t, int a) { }
}
//這個時候就能夠調用拓展方法了
Test t = new Test();
t.ActionExtension();
t.ActionExtension1(0);
注意:不支持擴展事件和屬性,可是能夠擴展接口
避免雙向耦合
雙向耦合指兩個類型之間互相引用.通常來講,類型之間不該該存在雙向耦合,若是出現,則考慮重構。