同步调用   : 委托的Invoke方法用来进行同步调用。同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行。

异步调用  :同步调用会阻塞线程,如果是要调用一项繁重的工作(如大量IO操作),可能会让程序停顿很长时间,造成糟糕
的用户体验,这时候异步调用就很有必要了。
异步调用不阻塞线程,而是把调用塞到线程池中,程序主线程或UI线程可以继续执行。
委托的异步调用通过BeginInvoke和EndInvoke来实现。

异步回调函数  :当异步调用时,主线程并没有等待,而是直接向下运行了。
但是问题依然存在,当主线程运行到EndInvoke时,如果这时调用没有结束(这种情况很可能出现),这时为了等待调用结果,线程依旧会被阻塞。
解决的办法是用回调函数,当调用结束时会自动调用回调函数

同步调用程序实现

class Program
      {
          //同步调用
          //委托的Invoke方法用来进行同步调用。同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行。
           public delegate int AddHandler(int a,int b);//声明委托
           static void Main(string[] args)
                {
                     Console.WriteLine("*******(同步调用)SyncInvokeTest*******");
                     AddHandler handler = new AddHandler(Add);//定义委托,传入参数
                     int result = handler.Invoke(1, 2);//委托的同步调用,主线程执行到此时停止,即阻塞。调用同步调用委托的的方法,执行此方法。
                     Console.WriteLine("(继续做其他的事)Do other work.....");//other work 是指Add方法,进行两数相加操作。
                     Console.WriteLine(result);
                     Console.ReadLine();
                 }

private static int Add(int a, int b)//一个加法方法是一个线程
                 {
                     Console.WriteLine("Computing"+a+" + "+b+"...");
                     Thread.Sleep(9000);//模拟方法进行9秒
                     Console.WriteLine("computing complete.");
                     return a + b;
                  }
      }

异步调用程序实现

class Program
        {
             //**************异步调用***********
            //异步调用不阻塞线程,而是把调用塞到线程池中,程序主线程或UI线程可以继续执行。
            //委托的异步调用通过BeginInvoke和EndInvoke来实现。
            public delegate int AddHandler(int a,int b);
            static void Main(string[] args)
                  {
                       Console.WriteLine("********(异步调用)AsyncInvokeTest******");
                       AddHandler handler = new AddHandler(Add);
                       IAsyncResult result = handler.BeginInvoke(1, 2, null, null);
                       Console.WriteLine("(继续做其他的事)do other work...");
                       Console.WriteLine(handler.EndInvoke(result));
                       Console.ReadLine();
                   }

private static int Add(int a, int b)
                  {
                      Console.WriteLine("computing "+a+"+"+b+"....");
                      Thread.Sleep(9000);//模拟方法进行9秒
                      Console.WriteLine("computing complete");
                      return a + b;
                   }
      }

异步调用加入回调函数程序实现

class Program
       {
             //**************异步回调***********
             //用回调函数,当调用结束时会自动调用回调函数,解决了为等待调用结果,而让线程依旧被阻塞的局面。

//注意: BeginInvoke和EndInvoke必须成对调用.即使不需要返回值,但EndInvoke还是必须调用,否则可能会造成内存泄漏。
            public delegate int AddHandler(int a, int b);
            static void Main(string[] args)
                    {
                         Console.WriteLine("********(异步回调调用)AsyncInvokeTest******");
                         AddHandler handler = new AddHandler(Add);
                         IAsyncResult result = handler.BeginInvoke(1, 2, new AsyncCallback(AddComplete),"AsycState:OK");
                         Console.WriteLine("(继续做其他的事)do other work...");
                         // Console.WriteLine(handler.EndInvoke(result));//对于每个异步操作只能调用一次EndInvoke()方法。
                         Console.ReadLine();
                     }

private static int Add(int a, int b)
                     {
                         Console.WriteLine("computing " + a + "+" + b + "....");
                         Thread.Sleep(3000);//模拟方法进行9秒
                          Console.WriteLine("computing complete");
                         return a + b;
                     }

static void AddComplete(IAsyncResult result)//异步回调函数
                    {
                        AddHandler handler = (AddHandler) ((AsyncResult) result).AsyncDelegate;
                       Console.WriteLine(handler.EndInvoke(result));
                       Console.WriteLine(result.AsyncState);
                     }
             //异步委托,也可以参考如下写法:
            //Action<object> action=(obj)=>method(obj);
            //action.BeginInvoke(obj,ar=>action.EndInvoke(ar),null);
           //简简单单两句话就可以完成一部操作。
       }

多线程是为了提高用户体验,解决窗体界面假死状态的好的选择。同步线程是阻塞线程,对提高用户体验和界面假死没什么帮助。异步线程才可以提高程序的性能,和用户体验。平时说的多线程是指异步线程。

C# 同步调用 异步调用 异步回调 多线程的作用的更多相关文章

  1. C#(同步调用、异步调用、异步回调)

    Review: 原作者虽然使用了汉字的类名,看起来十分蹩脚,但是,还是把同步调用.异步调用.异步回调的使用讲解的很详细的.原理讲解的很清晰. ------ 本文将主要通过“同步调用”.“异步调用”.“ ...

  2. java常见的几种调用机制(同步调用,异步调用,回调)

    1.同步调用 同步调用是最基本的调用方式,对象b中的方法直接调用对象a的方法,这个时候程序会等待对象a的方法执行完返回结果之后才会继续往下走. 代码如下: public class A {public ...

  3. Python并发编程06 /阻塞、异步调用/同步调用、异步回调函数、线程queue、事件event、协程

    Python并发编程06 /阻塞.异步调用/同步调用.异步回调函数.线程queue.事件event.协程 目录 Python并发编程06 /阻塞.异步调用/同步调用.异步回调函数.线程queue.事件 ...

  4. 委托(delegate)的三种调用方式:同步调用,异步调用,异步回调(转载)

    下面为即将被调用的方法: public delegate int AddHandler(int a,int b); public class 加法类 { public static int Add(i ...

  5. java三种调用方式(同步调用/回调/异步调用)

    1:同步调用:一种阻塞式调用,调用方要等待对方执行完毕才返回,它是一种单向调用 2:回调:一种双向调用模式,也就是说,被调用方在接口被调用时也会调用对方的接口: 3:异步调用:一种类似消息或事件的机制 ...

  6. C#“同步调用”、“异步调用”、“异步回调”

    本文将主要通过“同步调用”.“异步调用”.“异步回调”三个示例来讲解在用委托执行同一个“加法类”的时候的的区别和利弊. 首先,通过代码定义一个委托和下面三个示例将要调用的方法: ); //模拟该方法运 ...

  7. 整理 C#(同步调用、异步调用、异步回调)

    //闲来无事,巩固同步异步方面的知识,以备后用,特整理如下: class Program { static void Main(string[] args) { //同步调用 会阻塞当前线程,一步一步 ...

  8. C# 委托的三种调用示例(同步调用 异步调用 异步回调)

    首先,通过代码定义一个委托和下面三个示例将要调用的方法: 复制代码 代码如下: public delegate int AddHandler(int a,int b);    public class ...

  9. 用delegate实现.NET应用程序的同步函数的异步调用-.NET多线程编程实践之一

    在C++中有2种类型的线程:UI Thread和Worker Thread,前者是基于用户界面的有消息循环的线程.后者是没有用户界面的侧重于大时空运算的线程.直接调用Windows相关线程及同步对象的 ...

随机推荐

  1. 【leetcode】1110. Delete Nodes And Return Forest

    题目如下: Given the root of a binary tree, each node in the tree has a distinct value. After deleting al ...

  2. Vue最常用的组件通讯有三种:父->子组件通讯、子->父组件通讯,兄弟组件通讯.(template用的pug模板语法)

    Vue组件通讯   Vue最常用的组件通讯有三种:父->子组件通讯.子->父组件通讯,兄弟组件通讯.(template用的pug模板语法) 1.父->子组件通讯 父->子组件通 ...

  3. System.currentTimeMillis和System.nanoTime()

    ns(nanosecond):纳秒, 时间单位.一秒的10亿分之一,即等于10的负9次方秒.常用作 内存读写速度的单位.  1纳秒=0.000001 毫秒  1纳秒=0.00000 0001秒 jav ...

  4. 软件安装——彻底卸载MySQL

    如果你的电脑里装过MySQL,想再重新安装MySQL的时候可能就会因为前一版本卸载不彻底而出现错误.最常见的就是安装好后设置参数的最后一步验证时,会在Execute configurattion步骤中 ...

  5. 【bzoj4137】[FJOI2015]火星商店问题

    *题目描述: 火星上的一条商业街里按照商店的编号1,2 ,…,n ,依次排列着n个商店.商店里出售的琳琅满目的商品中,每种商品都用一个非负整数val来标价.每个商店每天都有可能进一些新商品,其标价可能 ...

  6. Leetcode 7. Reverse Integer(水)

    7. Reverse Integer Easy Given a 32-bit signed integer, reverse digits of an integer. Example 1: Inpu ...

  7. 支持向量机(四)----序列最小最优化算法SMO

    在支持向量机(二)和(三)中,我们均遗留了一个问题未解决,即如何求解原问题的对偶问题: 在支持向量机(二)中对偶问题为: 在支持向量机(三)中的对偶问题为: 对于上述两个对偶问题,我们在支持向量机(三 ...

  8. IDEA插件之自动查找bug工具

    打开idea 插件搜索界面 输入 FindBugs-IDEA,安装完成后重启,选中要查找的包,右键找到对应的 FindBugs就可以开始进行自动扫描了

  9. java导入ldif文件

    网上导入ldif文件的方式都是基于命令,或者相应工具如LDAP Browser \Editor v2.8.2. 但用java去实现这样的功能好像网上很少,于是我参照相应的开源代码并整理了一下,亲自测试 ...

  10. A* 算法求第 K 短路

    一种具有 \(f(n)=g(n)+h(n)\) 策略的启发式算法能成为 A* 算法的充分条件是: 搜索树上存在着从起始点到终了点的最优路径. 问题域是有限的. 所有结点的子结点的搜索代价值 \(> ...