有些书上也称“代表”或“委托”。
C# 中取消了指针的概念。对指针恋恋不舍的程序员可以有两种解决方法:声明“非安全”( unsafe )代码段然后在其中使用指针或者使用 C #的一个引用类型——“代理”( delegate )。“代理”相当与 C 中的函数指针原型,区别是 C #是类型安全 的。
“代理”( delegate )(代表、委托):“代理”是类型安全的并且完全面向对象的。
( 1 )在 C #中,所有的代理都是从 System.Delegate 类派生的( delegate 是 System.Delegate 的别名)。
( 2 )代理隐含具有 sealed 属性,即不能用来派生新的类型。
( 3 )代理最大的作用就是为类的事件绑定事件处理程序。
( 4 )在通过代理调用函数前,必须先检查代理是否为空( null ),若非空,才能调用函数。 ( 5 )在代理实例中可以封装静态的方法也可以封装实例方法。
( 6 )在创建代理实例时,需要传递将要映射的方法或其他代理实例以指明代理将要封装的函数原型( .NET 中称为方法签名: signature )。注意,如果映射的是静态方法,传递的参数应该是类名 . 方法名,如果映射的是实例方法,传递的参数应该是实例名 . 方法名。
( 7 )只有当两个代理实例所映射的方法以及该方法所属的对象都相同时,才认为它们是想等的(从函数地址考虑)。
( 8 )多个代理实例可以形成一个代理链, System.Delegate 中定义了用来维护代理链的静态方法 Combion , Remove ,分别向代理链中添加代理实例和删除代理实例。
( 9 )代理的定义必须放在任何类的外面,如 delegate int MyDelegate() ;而在类的方法中调用 MyDelegate d = new MyDelegate(MyClass.MyMethod) ;来实例化自定义代理的实例。
( 10 )代理三步曲:
a .生成自定义代理类: delegate int MyDelegate();
b .然后实例化代理类: MyDelegate d = new MyDelegate(MyClass.MyMethod);
c .最后通过实例对象调用方法: int ret = d();