自定义事件

简介:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Timers; // 计时器


namespace DemoConnection
{
    public delegate void MessageHandler(string messageText);
    public class Connection
    {
        public event MessageHandler MessageArrived; // 定义一个委托的实例
        private Timer pollTimer;

        public Connection()
        {
            pollTimer = new Timer(100);
            pollTimer.Elapsed += new ElapsedEventHandler(CheckForMessage); // 每一百毫秒执行一次
        }

        public void Connect()
        {
            pollTimer.Start();
        }

        public void Disconnect()
        {
            pollTimer.Stop();
        }

        private static Random random = new Random();
        private static int count = 0;

        private void CheckForMessage(object source,ElapsedEventArgs e)
        {
            Console.WriteLine("检测新消息.");
            if ((random.Next(9) == 0) && (MessageArrived != null))
            {
                count++;
                //触发MessageArrived事件
                MessageArrived("第"+count+"次问候您!");
            }
        }

    }

    public class Display
    {
        public void DisplayMessage(string message)
        {
            Console.WriteLine("消息来了:{0}",message);
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            Connection myConnection = new Connection();
            Display myDisplay = new Display();
            //将一个委托实例赋值给事件MessageArrived
            myConnection.MessageArrived += new MessageHandler(myDisplay.DisplayMessage);
            myConnection.Connect();
            Console.ReadKey();
        }
    }
}

方法论:说实话,我还不太理解这段代码。

本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/6803018.html,如需转载请自行联系原作者

相关文章
|
2月前
|
JavaScript 前端开发
除了点击事件,`addEventListener` 还能用于处理哪些事件类型?
【10月更文挑战第29天】 `addEventListener` 能够处理的事件类型非常丰富,涵盖了各种用户交互和页面状态变化的场景,通过合理地使用这些事件类型,可以为网页或应用程序添加丰富多样的交互效果和功能。
|
7月前
|
安全 API
(23):自定义事件
(23):自定义事件
|
JavaScript
62Vue - 自定义事件(使用自定义事件的表单输入组件)
62Vue - 自定义事件(使用自定义事件的表单输入组件)
47 0
|
8月前
事件监听
事件监听
|
8月前
|
前端开发 JavaScript UED
Vue3中的事件处理:事件绑定、事件修饰符、自定义事件
Vue3中的事件处理:事件绑定、事件修饰符、自定义事件
360 0
|
JavaScript API
61Vue - 自定义事件(使用 v-on 绑定自定义事件)
61Vue - 自定义事件(使用 v-on 绑定自定义事件)
43 0
|
JavaScript
Vue2事件及事件修饰符
从基础到实战,我们一环都不要少!
61 0
|
JavaScript
Vue学习之参数传递与事件分发使用this.$emit(‘自定义事件名‘, 参数)自定义事件删除待办事项
数据项在 Vue 的实例中,但删除操作要在组件中完成,那么组件如何才能删除 Vue 实例中的数据呢? 此时就涉及到参数传递与事件分发了,Vue 为我们提供了自定义事件的功能很好的帮助我们解决了这个问题;使用this.$emit(‘自定义事件名’, 参数),操作过程如下
203 0
|
JavaScript
事件处理
事件处理
143 0
|
前端开发
前端学习64-自定义事件
前端学习64-自定义事件
149 0
前端学习64-自定义事件