Observer模式和委托事件

本文深入探讨了.NET中事件与委托的基本概念及应用实例,通过两个案例解析了如何使用委托实现事件监听与触发机制,展示了不同场景下事件的注册与调用方式。

事件委托:event-delegate

事件是特殊的委托,无论我们是否定义public的事件,最终都会被编译成private的委托。

所以事件在外部无法赋值,但是事件有公共的remove,add方法,我们可以通过+=来注册事件。

委托必须先=赋值,然后才能用+=来附加委托。

通过IL DASM查看编译结果:

 

___[MOD] C:/MouseCatExample.exe
   |      M A N I F E S T
   |___[NSP] MouseCatExample
   |   |___[CLS] MouseCatExample.Cat
   |   |   |     .class public auto ansi beforefieldinit 
   |   |   |___[FLD] Eventhandler : private class MouseCatExample.Delegate
   |   |   |___[MET] .ctor : void()
   |   |   |___[MET] FireAway : void()
   |   |   |___[MET] add_Eventhandler : void(class MouseCatExample.Delegate)
   |   |   |___[MET] remove_Eventhandler : void(class MouseCatExample.Delegate)
   |   |   |___[EVT] Eventhandler : MouseCatExample.Delegate
   |   |
   |   |___[CLS] MouseCatExample.Delegate
   |   |   |     .class public auto ansi sealed 
   |   |   |      extends [mscorlib]System.MulticastDelegate 
   |   |   |___[MET] .ctor : void(object,native int)
   |   |   |___[MET] BeginInvoke : class [mscorlib]System.IAsyncResult(class [mscorlib]System.AsyncCallback,object)
   |   |   |___[MET] EndInvoke : void(class [mscorlib]System.IAsyncResult)
   |   |   |___[MET] Invoke : void()
   |   |
   |   |___[CLS] MouseCatExample.Master
   |   |   |     .class public auto ansi beforefieldinit 
   |   |   |___[MET] .ctor : void(class MouseCatExample.Cat)
   |   |   |___[MET] Action : void()
   |   |
   |   |___[CLS] MouseCatExample.Mouse
   |   |   |     .class public auto ansi beforefieldinit 
   |   |   |___[MET] .ctor : void(class MouseCatExample.Cat)
   |   |   |___[MET] Action : void()
   |   |
   |   |___[CLS] MouseCatExample.Program
   |   |   |     .class private auto ansi beforefieldinit 
   |   |   |___[MET] .ctor : void()
   |   |   |___[STM] Main : void(string[])
   |   |
   |

 

Case1:CatMouse:

public delegate void Delegate();

    public class Cat
    {
        public event Delegate Eventhandler;

        public void FireAway()
        {
            if (this.Eventhandler != null)
            {
                this.Eventhandler();
            }
        }
    }
    public class Master
    {
        public Master(Cat cat)
        {
            cat.Eventhandler += new Delegate(Action);
        }
        public void Action()
        {
            Console.WriteLine("master heared!");
        }
    }
    public class Mouse
    {
        public Mouse(Cat cat)
        {
            cat.Eventhandler += new Delegate(Action);
        }
        public void Action()
        {
            Console.WriteLine("mouse heared and run!");
        }
    }

static void Main(string[] args)
        {
            Cat cat = new Cat();
            Mouse mouse = new Mouse(cat);
            Master master = new Master(cat);
            cat.FireAway();
            Console.Read();

        }
View Code

Case2: HeaterAlarm

using System;
 using System.Collections.Generic;
 using System.Text;
 namespace Delegate {
        // 热水器
       public class Heater {
               private int temperature;
               public delegate void BoilHandler(int param);       //声明委托
              public event BoilHandler BoilEvent;                     //声明事件 

              // 烧水
              public void BoilWater() {
                      for (int i = 0; i <= 100; i++) {
                             temperature = i;

Www~
                             if (temperature > 95) {
                                    if (BoilEvent != null) {       //如果有对象注册
                                          BoilEvent(temperature);       //调用所有注册对象的方法
                                   } 
                             }
                      }
               }
        }
        // 警报器
       public class Alarm {
               public void MakeAlert(int param) {
                      Console.WriteLine(”Alarm:嘀嘀嘀,水已经 {0} 度了:”, param);
               }
        }

       // 显示器
       public class Display {
               public static void ShowMsg(int param) {       //静态方法
                     Console.WriteLine(”Display:水快烧开了,当前温度:{0}度。”, param);
               }
        }
       
        class Program {
               static void Main() {
                      Heater heater = new Heater();
                      Alarm alarm = new Alarm();

.

                     heater.BoilEvent += alarm.MakeAlert;       //注册方法
                     heater.BoilEvent += (new Alarm()).MakeAlert;       //给匿名对象注册方法
                     heater.BoilEvent += Display.ShowMsg;              //注册静态方法 .

                     heater.BoilWater();       //烧水,会自动调用注册过对象的方法
              }
        }
 }
View Code

 

转载于:https://www.cnblogs.com/lemonP/p/7059895.html

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化并行计算等改进策略。; 适合人群:具备一定Python编程基础优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值