C#委托事件的实现

news/2024/7/8 5:35:39 标签: c#, 委托事件, Winform

1、事件
在C#中事件是一种特殊的委托类型,用于在对象之间提供一种基于观察者模式的通知机制。
1.1、事件的发送方定义了一个委托,委托类型的声明包含了事件的签名,即事件处理器方法的签名。
1.2、事件的订阅者可以通过+=运算符来注册事件处理器。
1.3、当事件发送方触发事件时,所有注册的事件处理器会被依次调用。
2、委托事件的实现
2.1、事件发布类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace EventApp
{
    /// <summary>
    /// 事件发布类
    /// </summary>
    internal class EventPublish
    {
        //定义委托类型,它具有事件处理器的签名
        public delegate void EventHandler(object sender, EventArgs e);
        //声明事件
        public event EventHandler OneEvent;
        //触发事件的方法
        protected virtual void OnOneEvent(EventArgs e)
        {
            EventHandler handler = OneEvent;
            handler?.Invoke(this, e);
        }
        //示例方法,可以在需要的时候触发事件
        public void TriggerEvent()
        {
            OnOneEvent(EventArgs.Empty);
        }
    }
}

2.1、事件订阅类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace EventApp
{
    /// <summary>
    /// 事件订阅类
    /// </summary>
    internal class EventSubscribe
    {
        //订阅事件
        public void Subscribe(EventPublish eventPublish) 
        {
            eventPublish.OneEvent += EventPublish_OneEvent;
        }
        //事件处理函数
        private void EventPublish_OneEvent(object sender, EventArgs e)
        {
            Console.WriteLine("Event is triggered!");
        }
    }
}

2.3、委托事件的实现

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;

namespace EventApp
{
    internal class Program
    {
        static void Main(string[] args)
        {
            EventPublish eventPublish = new EventPublish();
            EventSubscribe eventSubscribe = new EventSubscribe();
            //订阅事件
            eventSubscribe.Subscribe(eventPublish);

            Console.Write("Press <Enter> to trigger event\n");
            while (Console.ReadKey().Key != ConsoleKey.Enter) { Thread.Sleep(100); }
            //触发事件
            eventPublish.TriggerEvent();
            Console.ReadKey();
        }
    }
}

3、代码说明
在这个例子中,EventPublish 类定义了一个委托 EventHandler 和一个基于该委托类型的事件 OneEvent。OnOneEvent 方法是触发事件的方法,它检查事件是否有注册的处理器,并按顺序调用它们。TriggerEvent 方法用于触发事件。EventSubscribe 类中的 Subscribe 方法用于订阅事件,并提供了事件处理器 EventHandler。在 Main 方法中,我们创建了 EventPublish 和 EventSubscribe 的实例,并通过 Subscribe 方法将 EventHandler 注册到 OneEvent 上。最后通过 TriggerEvent 方法触发了事件,控制台上输出了 “Event is triggered!”。
4、运行效果
在这里插入图片描述


http://www.niftyadmin.cn/n/5536589.html

相关文章

(已解决)Adobe Flash Player已不再受支持

文章目录 前言解决方案 前言 一般来说&#xff0c;很少遇到官方网站使用Adobe Flash Player来进行录用名单公示了。但是&#xff0c;今天就偏偏遇到一次&#xff0c; 用谷歌浏览器打不开&#xff0c; 点了没有反应&#xff0c;用其他的浏览器&#xff0c;例如windows自带的那…

react native优质开源项目

React Native 是一个非常流行的用于构建跨平台移动应用程序的框架&#xff0c;开源社区贡献了许多优质的项目和库。以下是一些备受认可的 React Native 开源项目&#xff0c;适合用来学习和参考&#xff1a; ### 1. **React Native Elements** [React Native Elements](https:…

SwiftUI八与UIKIT交互

代码下载 SwiftUI可以在苹果全平台上无缝兼容现有的UI框架。例如&#xff0c;可以在SwiftUI视图中嵌入UIKit视图或UIKit视图控制器&#xff0c;反过来在UIKit视图或UIKit视图控制器中也可以嵌入SwiftUI视图。 本文展示如何把landmark应用的主页混合使用UIPageViewController和…

yolo-seg模型后处理

yolo-seg模型mask处理 YOLOv8-seg模型一共有两个输出。第一个输出是“output0”&#xff0c;它的类型是float32[1,116,8400]。在这个输出中&#xff0c;前84个列与YOLOv8目标检测模型的输出定义相同&#xff0c;包括cx、cy、w、h这4项&#xff0c;再加上80个类别的分数。而后面…

事务的特性-原子性(Atomicity)、一致性(Consistency)、隔离性(Asolation)、持久性(Durability)

一、引言 1、数据库管理系统DBMS为保证定义的事务是一个逻辑工作单元&#xff0c;达到引入事务的目的&#xff0c;实现的事务机制要保证事务具有原子性、一致性、隔离性和持久性&#xff0c;事务的这四个特性也统称为事务的ACID特性 2、当事务保持了ACID特性&#xff0c;才能…

记一次因ThreadPoolExecutor多线程导致服务器内存压满问题

经过下载服务器内存数据得知是通过多线程业务处理查询list集合数据没有得到正确释放导致的。 首先先了解一下list集合数据的存放和回收&#xff08;可能说的不对&#xff0c;请谅解【挠头】&#xff09; 存放&#xff1a; 当我们创建一个list或者从数据库查询出的数据用list集…

iOS项目怎样进行二进制重排

什么是二进制重排 &#xff1f; 在iOS项目中&#xff0c;二进制重排&#xff08;Binary Reordering 或者 Binary Rearrangement&#xff09;是一种优化技术&#xff0c;主要目的是通过重新组织应用程序的二进制文件中的代码和数据段&#xff0c;来提高应用程序的性能&#xff…

一 、分布式软总线原理

分布式软总线(Distributed Soft Bus)是HarmonyOS(鸿蒙操作系统)中的关键技术之一,它负责提供设备间统一的分布式通信能力,使得不同终端设备能够像在同一台设备上一样进行高速、低延迟的数据传输和任务协同。在C++实现分布式软总线时,主要涉及以下几个核心部分: 设备发现…