委托+内置委托方法

Posted 千喜

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了委托+内置委托方法相关的知识,希望对你有一定的参考价值。

委托概念:如果我们要把方法当做参数来传递的话,就要用到委托。简单来说委托是一个类型,这个类型可以赋值一个方法的引用。

 

声明委托:

在C#中使用一个类分两个阶段,首选定义这个类,告诉编译器这个类由什么字段和方法组成的,然后使用这个类实例化对象。在我们使用委托的时候,也需要经过这两个阶段,首先定义委托,告诉编译器我们这个委托可以指向哪些类型的方法,然后,创建该委托的实例。 定义委托的语法如下:

delegate void IntMethodInvoker(int x);

定义了一个委托叫做IntMethodInvoker,这个委托可以指向什么类型的方法呢? 这个方法要带有一个int类型的参数,并且方法的返回值是void的。 定义一个委托要定义方法的参数和返回值,使用关键字delegate定义。 定义委托的其他案例:

delegate double TwoLongOp(long first,long second);

delegate string GetAString();

 

使用委托:

private delegate string GetAString();

static void Main(){
    int x = 40;
    GetAString firstStringMethod = new GetAString(x.ToString);
//a指向了x中的tostring方法
把方法名给一个委托的构造方法

//相当于GetAString a = x.ToString;ToString与GetAString返回类型和参数都是一样的,这是把方法名直接赋值给委托的实例
    Console.WriteLine(firstStringMethod()); 
}

 

在这里我们首先使用GetAString委托声明了一个类型叫做fristStringMethod,接下来使用new 对它进行初始化,使它引用到x中的ToString方法上,这样firstStringMethod就相当于x.ToString,我们通过firstStringMethod()执行方法就相当于x.ToString() 通过委托示例调用方法有两种方式

fristStringMethod();

firstStringMethod.Invoke();

委托类型可以作为一个参数来使用:

 private delegate void PrintString();

        static void PrintStr( PrintString print )
        {
            print();
        }

static void Method1() {
   Console.WriteLine("method1");
}
static void Method2() {
   Console.WriteLine("method2");
}

 

PrintString method = Method1;
PrintStr(method);
method = Method2;
PrintStr(method);

 

实例

定义一个类MathsOperations里面有两个静态方法,使用委托调用该方法
class MathOperations{
    public static double MultiplyByTwo(double value){
        return value*2;
    }
    public static double Square(double value){
        return value*value;
    }
}
delegate double DoubleOp(double x);
static void Main(){
    DoubleOp[] operations={ MathOperations.MultiplyByTwo,MathOperations.Square };
    for(int i =0;i<operations.Length;i++){
        Console.WriteLine("Using operations "+i);
        ProcessAndDisplayNumber( operations[i],2.0 );
    }
}
static void ProcessAndDisplayNumber(DoubleOp action,double value){
    double res = action(value);
    Console.Writeline("Value :"+value+" Result:"+res);
}

 

 

Action委托和Func委托(内置委托类型):

除了我们自己定义的委托之外,系统还给我们提供过来一个内置的委托类型,Action和Func

Action委托引用了一个void返回类型的方法,T表示方法参数,先看Action委托有哪些

Action Action<in T>

Action<in T1,in T2>

Action<in T1,in T2 .... inT16>

//action可以后面通过泛型去指定action指向的方法的多个参数的类型 ,参数的类型跟action后面声明的委托类型是对应着的
    Action a = PrintString;//action是系统内置(预定义)的一个委托类型,它可以指向一个没有返回值,没有参数的方法
    Action<int> a = PrintInt;//定义了一个委托类型,这个类型可以指向一个没有返回值,有一个int参数的方法
    Action<string> a = PrintString;//定义了一个委托类型,这个类型可以指向一个没有返回值,有一个string参数的方法 在这里系统会自动寻找匹配的方法
    Action<int, int> a = PrintDoubleInt;//多个参数,指向两个int参数的无返回值的函数

 

 

Func引用了一个带有一个返回值的方法,它可以传递0或者多到16个参数类型,和一个返回类型

Func<out TResult>

Func<in T,out TResult>

Func<int T1,inT2,,,,,,in T16,out TResult>

Func<int> a = Test1;//func中的泛型类型指定的是 方法的返回值类型
Func<string, int> a = Test2;//func后面可以跟很多类型,最后一个类型是返回值类型前面的类型是参数类型,参数类型必须跟指向的方法的参数类型按照顺序对应
Func<int, int, int> a = Test3;//func后面必须指定一个返回值类型,参数类型可以有0-16个,先写参数类型,最后一个是返回值类型
            int res = a(1, 5);

 

以上是关于委托+内置委托方法的主要内容,如果未能解决你的问题,请参考以下文章

lambda表达式之进化

对“xxx”类型的已垃圾回收委托进行了回调。这可能会导致应用程序崩溃损坏和数据丢失。向非托管代码传递委托时,托管应用程序必须让这些委托保持活动状态,直到确信不会再次调用它们。 错误解决一例。(代码片段

C#中常见的系统内置委托用法详解

多播委托的特点

关于内置委托的用法

iOS UIPopoverController委托不工作,仍然是零