Делегат C# реализует механизм обратного вызова (основное понимание)

/*

Делегаты реализуют обратные вызовы: механизм
    передачи обратных вызовов с методами в качестве параметров через делегаты
    : от вызывающей стороны -> стороны определения -> вызывающей стороны -> стороны определения -> вызывающей стороны

    Вызывающий объект выполняет метод (параметр метода содержит доверенный тип) -> 
    входит в порт определения метода, выполняет блок кода в методе, выполняет доверенный метод ->
    возвращает вызывающему объекту для выполнения переданного параметра метода ->
    возвращает до конца определения и продолжает выполняться Блок кода ->
    вернуться к вызывающей программе после выполнения

*/


class TestCallBack
{     TesHandler handler =new TesHandler();     // 1. Выполнить метод (при условии, что метод является точкой входа, выполнить метод)     public void DebugResult()     {         // 2. Затем выполнить метод         handler.Result(3) , 2 , (a,b)=>{return a+b;});//5. Вернуться к вызывающей программе и выполнить (a,b)=>{return a+b;} }//8. Выход вызывающий      метод }








class TesHandler 
{     //3. Введите результат      public int Result(int a, int b, CalTestHandler calHandler)     {         //4. Вызовите метод делегата         return calHandler(a, b);//6. Вернитесь в конец определения и выполните it     }/ /7.Выйти из определенного конечного метода





    // Определяем
    открытый делегат делегата int CalTestHandler(int a, int b);

}

/*

委托实现回调:
    通过委托以方法作为参数进行传递
    回调的机制:从调用端 -> 定义端 -> 调用端 -> 定义端 -> 调用端

    调用端 执行方法(方法参数含有委托类型) -> 
    进入到定义方法端口,执行方法中的代码块,执行到委托方法 ->
    回到调用端执行传递的方法参数 ->
    回到定义端 继续执行后面的代码块 ->
    执行完毕 回到调用端

*/


class TestCallBack
{
    TesHandler handler =new TesHandler();
    //1.执行该方法(假设该方法为入口 即执行该方法)
    public void DebugResult()
    {
        //2.进而执行该方法
        handler.Result(3, 2, (a,b)=>{return a+b;});//5.回到调用端 执行(a,b)=>{return a+b;} 
    }//8.退出调用端方法
}


class TesHandler 
{
    //3.进入Result 
    public int Result(int a, int b , CalTestHandler calHandler )
    {
        //4.调用委托方法
        return calHandler(a, b);//6.回到定义端 执行完毕
    }//7.退出定义端方法

    //定义委托
    public delegate int CalTestHandler(int a, int b);

}

Supongo que te gusta

Origin blog.csdn.net/weixin_44906202/article/details/128322808
Recomendado
Clasificación