浅谈委托,事件,异步调用,回调等概率

直接说题。

委托

        首先明确它是什么,其实就是一个类,定义一个委托即定义一个类,那么它是什么类?用来说明方法的类型的类。字段有类型,那么方法其实也有类型,就是委托。

      委托是某一类方法的总定义。

   事件

          事件是某个类用于传递消息的方式。事件之余委托,犹如属性之余变量即是委托的封装。

    好了,明确了概念,接下来说示例。

   示例

        有3个对象  鼠标,button,winform 。鼠标点击button对象,触发button的click事件,winform捕获到了事件然后进行了处理。

       含义:button是类,有个click事件,其被点击后,向外部发送了一个消息“我被点击了”,winform说“我来处理”,winform是怎么捕获的呢?连接它们之间的桥梁

其实就是委托。winform通过某一类委托向button的click事件注册自己的方法,当事件发生的时候,方法自然就被调用了。

       举个现实中的例子,可能不太恰当。 当我们开车,发生车祸事件时,交警会到现场进行处理,而不是消防或医生或其他人。其实背后就是一个逻辑,预定义好的,车祸是交警处理,火灾是消防处理,生病是医生处理。

        接下来说异步调用。

  异步调用和回调

        顾名思义,异步即不同步,如何体现不同步呢? .net的实现是采用一个新的线程中执行你的方法(不知道理解的对不对:))

       为什么要异步呢?简单说winform吧,就是不希望主线程被长时间执行的方法所阻塞,造成不好的用户体验,谁也不希望数据加载时窗体一拉,界面卡死,是吧。

      那如何实现异步呢?首先定义委托。你肯定会说为什么?  因为委托类中有begininvoke方法,我猜测begininvoke方法的实现里可能包含了开辟新线程,然后在新线程中执行你的需要异步执行的方法。

     好了,方法开始异步执行了。那我怎么知道它执行完了没有啊?使用回调。

    你要问了回调是什么玩意啊?回调即回过头来调用,那么是谁回过头?begininvoke开辟的新线程回头调主线程的方法。那目的呢?通知主线程“我执行结束了你看着办”

   那么怎么实现呢?我的方法是委托和事件。异步调用的方法在执行完成后触发一个完成的事件,这个事件定义在winform中,谁来处理呢?winform中的方法。

    接下来,贴上我的代码。例子比较简单:)

    

   

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace WindowsFormsApplication1
{
    public partial class Form1 : Form
    {
        public delegate void ProcessHandler(int i);
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            //process();主线程直接调用会阻塞
            this.button1.Text = "加载中。。。。";
            new System.Threading.Thread(new System.Threading.ThreadStart(process)).Start();
            this.button1.Text="加载完成";
        }

        private void process()
        {
            for (int i = 0; i < 50; i++)
            {
                System.Threading.Thread.Sleep(500);
                setlist(i);
            }
        }

        private void setlist(int i)
        {
            if (this.InvokeRequired)
            {
                this.BeginInvoke(new ProcessHandler(setlist), new object[] { i });
                return;
            }
            this.listBox1.Items.Add(i);
        }

        private void button2_Click(object sender, EventArgs e)
        {
            MessageBox.Show("sssss");
        }

        private void process(ref bool isfinished)
        {
            for (int i = 0; i < 20; i++)
            {
                System.Threading.Thread.Sleep(500);
                setlist(i);
            }
            isfinished = true;
            finished(ref isfinished);
        }

        public delegate void HeadProcess(ref bool isfinish);
        public event HeadProcess finished;
        private void button3_Click(object sender, EventArgs e)
        {
            this.button3.Text = "加载中。。。。";
            bool isfinished = false;
            this.listBox1.Items.Clear();
            HeadProcess hp = new HeadProcess(this.process);
            IAsyncResult ia = hp.BeginInvoke(ref isfinished, null, null);            finished += this.setstatus;//注册完成事件的处理方法

        }
        private void setstatus(ref bool isfinished)
        {
            if (this.InvokeRequired)
            {
                this.BeginInvoke(new HeadProcess(this.setstatus),new object[]{isfinished});
                return;
            }

            if (isfinished)
            {
                this.button3.Text = "加载完成";
                MessageBox.Show("加载完成");
            }
            else
            {
                this.button3.Text = "加载失败";
            }
        }

    }
}

第一次写文,比较粗糙,大家凑合看看, 以上解释均为我个人的理解,如有不对,请大家吐槽。:)

时间: 2024-10-23 21:56:29

浅谈委托,事件,异步调用,回调等概率的相关文章

浅谈委托和事件(一)

浅谈委托和事件(一) 关于委托和事件,可能是.NET或者说是面向对象编程语言中的一个比较重要又比较难以理解的概念.关于这一话题,园子里的人也写了很多文章,最经典的可能就是张子阳的C#中的委托和事件这两篇文章了,之前也看过MSDN 上的WebCast深入 "委托和事件".可能和很多人一样,刚开始读的时候,觉得很清楚,但是过了一段时间好像又忘记了委托和事件的区别,知道很久以前,在一次面试中我被问到委托和事件有什么区别,一下子就说不清了. 所以这里稍微理一下,也算是自己的一个总结.当然,还是

C#委托的异步调用

#委托的异步调用本文将主要通过"同步调用"."异步调用"."异步回调"三个示例来讲解在用委托执行同一个"加法类"的时候的的区别和利弊.   首先,通过代码定义一个委托和下面三个示例将要调用的方法: /*添加的命名空间using System.Threading;using System.Runtime.Remoting.Messaging;*/    public delegate int AddHandler(int a,i

C#委托的异步调用1

本文将主要通过“同步调用”.“异步调用”.“异步回调”三个示例来讲解在用委托执行同一个“加法类”的时候的的区别和利弊. 首先,通过代码定义一个委托和下面三个示例将要调用的方法: /*添加的命名空间using System.Threading;using System.Runtime.Remoting.Messaging;*/    public delegate int AddHandler(int a,int b);    public class 加法类    {        public

【浅谈DOM事件的优化】

浅谈DOM事件的优化 在 JavaScript程序的开发中,经常会用到一些频繁触发的 DOM 事件,如 mousemove.resize,还有不是那么常用的鼠标滚轮事件:mousewheel (在 Firefox 中,滚轮事件为 DOMMouseScroll). 浏览器为了确保这些事件能够及时响应,触发的频率会比较高,具体的触发频率各浏览器虽然有出入,但出入不大.很多时候在需要注重性能的场景下使用这些事件会想各种办法对事件的触发频率进行优化,下面说说我的一些优化方法. mousemove 在拖拽

浅谈Android 事件分发机制(一)

在上一篇文章中,浅谈Android 事件分发机制(一),简要分析了一下事件分发机制的原理,总结一下就是事件层层传递,直到被消费,原理看似简单,但是在实际使用过程中,场景各不相同,复杂程度也就因产品而异,这篇文章就通过给view加移动来模拟事件分发. 触摸事件 这里涉及到几个与手指触摸相关的常见事件: 坐标系对于单指触控移动来说,一次简单的交互流程是这样的:手指落下(ACTION_DOWN) -> 移动(ACTION_MOVE) -> 离开(ACTION_UP) 坐标系 Android坐标系以手

利用委托实现异步调用

同步调用示例(委托是一个类型安全的,面向对象的指针) using System; using System.Threading; namespace Demo { public delegate int Operate(int x, int y); public class DelegateAsync { static int Add(int a, int b) { Console.WriteLine ("Add() invoked on thread:{0}\n", Thread.C

c# 委托与异步调用

背景:在winform UI中,有时需要对控件进行比较频繁的刷新,如进度条.picturebox显示视频等.如果在主线程进行这些刷新操作,操作还未完成就将执行下一次刷新,程序将发生错误:如果只是创建另一个线程执行这些操作,将和主线程产生竞争,造成界面锁死(因此windows GUI编程有一个规则,就是只能通过创建控件的线程来操作控件的数据,否则就可能产生不可预料的结果).这时候,我们就可以用委托与异步来解决这个问题. 委托:回顾一下委托 ,一.定义委托,委托定义的参数与传递给委托的方法的参数一致

浅谈Javascript事件模拟

事件是用来描述网页中某一特定有趣时刻的,众所周知事件通常是在由用户和浏览器进行交互时触发,其实不然,通过Javascript可以在任何时间触发特定的事件,并且这些事件与浏览器创建的事件是相同的.这就意味着会有适当的事件冒泡,并且浏览器会执行分配的事件处理程序.这种能力在测试web应用程序的时候,是非常有用的,在DOM 3级规范中提供了方法来模拟特定的事件,IE9 chrome FF Opera 和 Safari都支持这样的方式,在IE8及以前的办法的IE浏览器有他自己的方式来模拟事件a)Dom

新手浅谈C#Task异步编程

Task是微软在.net framework 4.0发布的新的异步编程的利器,当然4.5新增了async.await,这儿我们先说Task相关. 在实际编程中,我们用的较多的是Task.Task.Factory.StarNew.Task.Run,接下来简单的表述下我的理解. //传入Func委托 Task<int> task = new Task<int>(a => { return (int)a + 1; }, 1); task.Start(); Console.Write