C#委托事件的区别

在C#中,委托(delegate)和事件(event)经常一起使用,但它们之间确实有一些基本的区别:

  1. 委托(Delegate):委托是一个引用类型,它可以引用一个或多个具有特定签名的方法。简单地说,你可以将其视为一个类型安全的函数指针。

  2. 事件(Event):事件基于委托来实现,但它添加了一层封装,使得对象的其他部分不能直接调用或修改事件,除非是那些声明了这个事件的类。事件通常用于在类之间通信,一个类可以发布一个事件,而其他类可以订阅这个事件。

示例代码

委托:

cs 复制代码
// 定义一个委托
public delegate void MyDelegate(string message);

public class MyClass
{
    // 使用委托
    public MyDelegate MyAction;

    public void TriggerAction()
    {
        MyAction?.Invoke("Triggered action!");
    }
}

public class Program
{
    public static void Main()
    {
        MyClass obj = new MyClass();
        obj.MyAction += DisplayMessage;
        obj.TriggerAction();
    }

    static void DisplayMessage(string message)
    {
        Console.WriteLine(message);
    }
}

事件:

cs 复制代码
public delegate void MyEventHandler(string message);

public class EventPublisher
{
    // 使用事件
    public event MyEventHandler MyEvent;

    public void RaiseEvent()
    {
        MyEvent?.Invoke("Event raised!");
    }
}

public class Program
{
    public static void Main()
    {
        EventPublisher publisher = new EventPublisher();
        publisher.MyEvent += OnMyEventOccurred; // 订阅事件
        publisher.RaiseEvent();
    }

    static void OnMyEventOccurred(string message)
    {
        Console.WriteLine(message);
    }
}

注意:

  • 在委托的例子中,我们可以直接访问和修改MyAction委托。
  • 在事件的例子中,我们不能直接访问或修改MyEvent事件(例如,不能直接调用或设置为null),但我们可以使用+=订阅事件和使用-=取消订阅事件。

这样,事件提供了更好的封装和控制,使外部代码不能直接调用或修改事件,除非是那些声明了这个事件的类。

相关推荐
军训猫猫头14 分钟前
1.如何对多个控件进行高效的绑定 C#例子 WPF例子
开发语言·算法·c#·.net
真的想上岸啊27 分钟前
学习C++、QT---18(C++ 记事本项目的stylesheet)
开发语言·c++·学习
明天好,会的34 分钟前
跨平台ZeroMQ:在Rust中使用zmq库的完整指南
开发语言·后端·rust
丁劲犇1 小时前
用 Turbo Vision 2 为 Qt 6 控制台应用创建 TUI 字符 MainFrame
开发语言·c++·qt·tui·字符界面·curse
旷世奇才李先生1 小时前
Next.js 安装使用教程
开发语言·javascript·ecmascript
charlie1145141912 小时前
深入理解Qt的SetWindowsFlags函数
开发语言·c++·qt·原理分析
likeGhee3 小时前
python缓存装饰器实现方案
开发语言·python·缓存
whoarethenext3 小时前
使用 C++/Faiss 加速海量 MFCC 特征的相似性搜索
开发语言·c++·faiss
项目題供诗3 小时前
黑马python(二十五)
开发语言·python
慌糖3 小时前
RabbitMQ:消息队列的轻量级王者
开发语言·javascript·ecmascript