Fork me on GitHub

.net知识和学习方法系列(二十)CLR-委托

delegate void DL(int i);

上面是一个委托的定义,委托向外提供了一种回调函数的机制,在.net中的委托是类型安全的,一个委托能实现对一类方法的回调,这个统一是通过委托的参数和返回值来实现的。

上面代码如果用IL来解释,是这个样子

 

 

如果用C#来表示,一个委托就成了下面的代码

  class DL:System .MulticastDelegate

   {

       public DL(Object object,IntPtr method);

       public virtual void Invoke(Int32 i);

       public virtual IAsyncResult BeginInvoke(Int32 i,AsyncCallback callback,Object object);

       public virtual void EndInvoke(IAsyncResult result);    

   }

当然,上面代码是通不过编译的,只是对应IL代码的表现。

在上面的类中,有一个构造函数,和三个方法,同时还有三个继承至MulticastDelegate的三个非公有字段_target,_methodPtr,_invocationList。

在构造函数中有两个参数,第一个是object类型,这里指的是被回调方法的对象,如果该方法是静态的,那么这个值就是null,第二个参数是个IntPtr,这个参数是回调方法。并且在构造器中,会把object赋给_target,IntPtr赋给_methodPtr来保存。

另外一个字段_invocationList是一个存放回调方法的链表。

static void Main(string[] args)

        {

            Program p = new Program();

            DL dl = new DL(p.FF);

            dl += p.FF;

            dl += FF1;

            dl(1);

        }

        public static void FF1(int i)

        {

            Console.WriteLine("d");

        }

        public void FF(int i)

        {

            Console.WriteLine(DateTime .Now .ToString ());

        }

上面代码的+=的过程,其实就是向_invocationList添加委托的过程。

还有代码中,我们调用了dl(1),这个代码其实是dl.Invoke(1)。

后两个方法的使用,可参看http://www.cnblogs.com/axzxs2001/archive/2008/04/17/1157269.html

posted @ 2008-09-29 12:59  桂素伟  阅读(422)  评论(0编辑  收藏  举报