C# 委托 事件 匿名方法

简介: (*) 委托 delegate从最简单的例子开始:namespace ConsoleApplication1{ class Program { // 委托其实就相当于一个类型。这里,类型的名字叫BinaryOp public delegate int BinaryOp(int x, int y); static p

(*) 委托 delegate

从最简单的例子开始:

namespace ConsoleApplication1
{    
    class Program
    {
        // 委托其实就相当于一个类型。这里,类型的名字叫BinaryOp
        public delegate int BinaryOp(int x, int y);
        static public int Add(int x, int y)
        {
            return x + y;
        }
        static void Main()
        {
            // 创建一个BinaryOp类型的实例,用静态Add方法初始化
            BinaryOp d = new BinaryOp(Add);
            Console.WriteLine(d(10, 10));
   Console.ReadLine(); 
        }
    }
}

输出结果为:20

上面是静态方法的委托,下面再来看一个实例方法的委托。
class MyClass
{
    private string name;
    public MyClass(string name)
    {
        this.name = name;
    }
    public void DisplayName() 
    {
        Console.WriteLine("{0}", name);
    }
}
class Program
{
    // 委托其实就相当于一个类型。这里,类型的名字叫SimpleDelegate
    public delegate void SimpleDelegate();        
    static void Main()
    {
        MyClass a = new MyClass("A");
        MyClass b = new MyClass("B");
        // 用实例方法DisplayName初始化
        SimpleDelegate d = new SimpleDelegate(a.DisplayName);            
        d();
        d = new SimpleDelegate(b.DisplayName);
        d();
 Console.ReadLine(); 
    }
}

输出结果为:A

                       B  

(*) 事件
委托是个类型,而事件是个成员。看下面的代码:

namespace ConsoleApplication1
{
    public class SimpleMath
    {
        public delegate int BinaryOp(int a, int b); // 定义Binary类型
        public event BinaryOp BinaryEvent; // 定义BinaryEvent成员
        public int Add(int a, int b) { return a + b; }
        public int Substract(int a, int b) { return a - b; }
        public int Calculate() 
        {
            // Raise the event by using the () operator.
            return BinaryEvent(1, 2); // 只能在定义事件的类的内部调用,如果写在外面会编译不过
        }
    }

    class Program
    {
        static void Main() 
        {
            SimpleMath sm = new SimpleMath();
            // sm.BinaryEvent(1, 2); 编译错误!只能在定义事件的类的内部调用
            // 下面两种注册方法效果是一样的,相当于注册了两遍,也的确会依序执行两遍
            sm.BinaryEvent += new SimpleMath.BinaryOp(sm.Add);
            sm.BinaryEvent += sm.Add;
            Console.WriteLine(sm.Calculate()); // 结果是3
            // 下面两种注册方法效果是一样的,相当于注册了两遍,也的确会依序执行两遍
            sm.BinaryEvent += new SimpleMath.BinaryOp(sm.Substract);
            sm.BinaryEvent += sm.Substract;            
            Console.WriteLine(sm.Calculate()); // -1, 只保留最后一次调用的返回值(3,3,-1,-1)
             Console.ReadLine(); 
        }                
    }
}

输出结果为:3

                      -1

(*) 匿名方法
匿名方法的作用是使代码更简化,方便了程序员。如果没有匿名方法,则定义一套事件监听需要这样:

class Program
{
    public delegate void SomeDelegate(); // 定义委托
    
    static void Main()
    {
        SomeType obj = new SomeType();
        obj.SomeEvent += new SomeDelegate(MyEventHandler);
    }
    // 一般来说,定义的MyEventHandler方法只用来响应事件,只在上面那一处地方使用
    public static void MyEventHandler() // 定义委托所调用的方法
    {}
}
上面的代码比较啰嗦,尤其是为委托和它所调用的方法起名字比较费劲我觉得。有了匿名方法以后,仅需要这样:
class Program
{
    static void Main()
    {
        SomeType obj = new SomeType();
        obj.SomeEvent += delegate{
            // 实现事件处理逻辑
        }; // 注意要有分号
    }    
}
与上一段代码相比,省去了SomeDelegate和MyEventHandler的定义。

拓展: 点击打开链接
目录
相关文章
|
C# 设计模式 编译器
C# 从函数到委托
原文地址:http://bbs.csdn.net/topics/390784442 看这样的程序: C# code? 1 2 3 4 5 6 7 8 9 10 11 12 int sum = 0; for (int i = 1; i <= 100; i++)
982 0
|
数据安全/隐私保护
委托(二):使用事件来对委托变量进行封装
          接上篇:委托(一):委托与方法                         在以前学习设计模式的时候,我们经常看到这样的代码:                                     可以这样说,委托和事件经常一起使用,感觉挺麻烦的,而且觉得委托已经挺好了,为什么还要加入事件呢?搞得挺复杂的。
942 0
|
设计模式
委托(一):委托与方法
   一,利用委托将方法作为方法的参数                 首先来看个小例子:               namespace 委托示例2 { /***** * 委托示例一 * 说明:此段程序主要是将委托作为方法的参数传入方法中,使得具体调用时再根据需要为方法赋值。
845 0
|
C# 设计模式
C#中的委托与事件
定义   委托是对函数的封装,可以当做给方法的特征制定一个名称。而事件则是委托的一种特殊形式,当发生有意义的事情时,事件对象处理通知过程。事件其实就是设计模式中观察者模式在.NET中的一种实现方式,现在还没接触,以后慢慢理解。
709 0