C#中的委托源码演示

在研发期间,把写代码过程中较好的一些代码段备份一下,下面的代码是关于C#中的委托演示的代码,应该能对小伙伴有些帮助。

public class Test 

    public delegate void D_Math(int a, int b); 

    public void Add(int a, int b) 

    { 

        Console.WriteLine("Add方法结果:{0}", a + b); 

    } 

    public void Cut(int a, int b) 

    { 

        Console.WriteLine("Cut方法结果:{0}", a - b); 

    } 

[TestClass] 

public class UnitTest1 

    [TestMethod] 

    public void TestMethod1() 

    { 

        Test t = new Test(); 

        D(5, 6); 


    } 




以上看出来委托实用的地方了吗?即委托可以执行任何引入参数类型相同且返回类型相同的方法,甚至可以执行签名相同的方法队列。那么我们的方法签名(即引入参数和输出参数)真的必须与委托完全一致吗?答:不是的,我们不能忽略协变与逆变。我们这里简单介绍一下协变与逆变的知识。“协变”是指能够使用与原始指定的派生类型相比,派生程度更大的类型。“逆变”则是指能够使用派生程度更小的类型。那么,我们的委托也是接受协变与逆变的。意思是,如果定义一个delegate,那么不仅仅签名完全相同的方法可以赋值给delegate变量。如果一个方法的参数表符合delegate声明,但返回的类型是(delegate声明返回类型)的派生类,那也可以将这个方法赋值给这个delegate变量。如果一个方法的返回类型符合delegate的声明,但参数是(delegate声明参数类型)的祖先类,那也可以将这个方法赋值给这个delegate变量。如果一个方法的参数和返回类型都符合上面两行的假设,那也可以将这个方法赋值给这个delegate变量。以下以两个简单示例解释协变与逆变:协变:




      public class A { } 

    public class Test 

    { 

        public delegate A D_Math(); 

        public B Add() 

        { 

            return new B(); 


        } 

        public A Add2() 

        { 

            return new A(); 

        } 

    } 

    [TestClass] 

    public class UnitTest1 

    { 

        [TestMethod] 

        public void TestMethod1() 

        { 

        } 

    } 




逆变:




public class A { } 

  public class Test 

  { 

      public delegate void D_Math(B b); 

      public void Add(B b) 

      { 


      } 

      public void Add2(A a) 

      { 


      } 

  } 

  [TestClass] 

  public class UnitTest1 

  { 

      [TestMethod] 

      public void TestMethod1() 

      { 

      } 

  } 




以上是本篇对于委托的讲解,欢迎大家补充与修正。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容