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);
注意:不支持扩展事件和属性,可是能够扩展接口
避免双向耦合
双向耦合指两个类型之间互相引用.通常来讲,类型之间不该该存在双向耦合,若是出现,则考虑重构。