委托的异步调用
异步多线程的三大特点:
1.同步方法卡界面,原因是主线程被占用;异步方法不卡界面,原因是计算交给了别的线程,主线程空闲
2.同步方法慢,原因是只有一个线程计算;异步方法快,原因是多个线程同事计算,但是更消耗资源,不宜太多
3.建议线程的数量不要超过 CPU核数*4
4.异步多线程是无序的,启动顺序不确定、执行时间不确定、结束时间不确定

        private void btnAsync_Click(object sender, EventArgs e)
{
Stopwatch watch = new Stopwatch();
watch.Start();
Console.WriteLine();
Console.WriteLine("********************btnAsync_Click Start 主线程id={0}********************", Thread.CurrentThread.ManagedThreadId);
Func <string,string> method = new Func<string,string >(this.TestThread);
IAsyncResult[] asyncResult = new IAsyncResult[]; for (int i = ; i < ; i++)
{
//在这个BeginInvoke方法是拿不到委托函数的返回值的
//第二个参数是一个委托(AsyncCallback),输入是异步调用的返回值
asyncResult[i] = method.BeginInvoke(string.Format("btnAsync_Click_{0}", i), t =>//异步调用的返回值
{
//Console.WriteLine(t.Equals(asyncResult));//这里证明t就是异步调用的返回值
//Console.WriteLine(t.AsyncState);//显示状态参数:yoyo_{0}
Console.WriteLine("这里是回调函数 {0}", Thread.CurrentThread.ManagedThreadId);
}, string.Format ("yoyo_{0}",i)); //最后是一个状态参数
} //做一个计时器等待异步完成
/* int j = 1;
while(!asyncResult[0].IsCompleted || !asyncResult[1].IsCompleted || !asyncResult[2].IsCompleted || !asyncResult[3].IsCompleted || !asyncResult[4].IsCompleted)
{
Console.WriteLine("**********正在计算,已完成{0}%**********",10*j++);
Thread.Sleep(200);
}*/ //WaitOne不能拿到委托函数的返回值
/* asyncResult[0].AsyncWaitHandle.WaitOne(); //一直等待这个异步结束
//asyncResult[0].AsyncWaitHandle.WaitOne(-1); //一直等待这个异步结束
//asyncResult[0].AsyncWaitHandle.WaitOne(200);//只等200毫秒
asyncResult[1].AsyncWaitHandle.WaitOne();
asyncResult[2].AsyncWaitHandle.WaitOne();
asyncResult[3].AsyncWaitHandle.WaitOne();
asyncResult[4].AsyncWaitHandle.WaitOne();*/ //Eninvoke可以拿到委托函数的返回值
Console.WriteLine(method.EndInvoke(asyncResult[]));
Console.WriteLine(method.EndInvoke(asyncResult[]));
Console.WriteLine(method.EndInvoke(asyncResult[]));
Console.WriteLine(method.EndInvoke(asyncResult[]));
Console.WriteLine(method.EndInvoke(asyncResult[])); watch.Stop();
Console.WriteLine("********************btnAsync_Click End 主线程id={0} {1}********************", Thread.CurrentThread.ManagedThreadId, watch.ElapsedMilliseconds);
Console.WriteLine();
}
       private string TestThread(string name)
{
Console.WriteLine("TestThread Start Name={2},当前线程的id:{0},当前时间为{1}", Thread.CurrentThread.ManagedThreadId, DateTime.Now.ToString("hh:mm:ss:fff"), name);
long Sum = ;
for (int i = ; i < ; i++)
{
Sum += i;
}
//Thread.Sleep(2000);
Console.WriteLine("TestThread End Name={2},当前线程的id:{0},当前时间为{1}", Thread.CurrentThread.ManagedThreadId, DateTime.Now.ToString("hh:mm:ss:fff"), name);
return string.Format("运行结果为:{0} {1}", name, Sum);
}

异步 BeginInvoke的更多相关文章

  1. 多线程 异步 beginInvoke EndInvoke 使用

    有许多耗时操作时,还要响应用户操作.这时候就需要用其他线程或者异步来搞.本来是改造公司的日志组件.因为多上了个国外大区的业务到来本系统来.这个系统其他地方都好就是日志,动不动就要死给我们看.有时候寻找 ...

  2. c#异步Begininvoke使用随笔

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  3. C#异步编程(二)

    async和await结构 序 前篇博客异步编程系列(一) 已经介绍了何谓异步编程,这篇主要介绍怎么实现异步编程,主要通过C#5.0引入的async/await来实现. BeginInvoke和End ...

  4. Dispatcher中Invoke与BeginInvoke

    [同步]Invoke Application.Current.Dispatcher.Invoke(AutoIncreaseNumber); [异步]BeginInvoke Application.Cu ...

  5. C#中异步调用示例与详解

    using System; using System.Collections.Generic; using System.Text; using System.Runtime.InteropServi ...

  6. Net线程间通信的异步机制

    线程间通信 我们看下面的图 我们来看线程间通信的原理:线程(Thread B)和线程(Thread A)通信, 首先线程A 必须实现同步上下文对象(Synchronization Context), ...

  7. C# WinForm 跨线程访问控件

    问题出现: 在WinForm 处理多线程访问主线程的控件时候,就会出现如图所示的错误对话框:    解决方案:  方案一:去掉线程访问主线程UI控件的安全检查,使用: Control.CheckFor ...

  8. .NET C#-- 利用BeginInvoke与EndInvoke完成异步委托方法并获取方法执行返回值示例

    //定义委托 delegate string MyDelegate(string name); //定义委托调用函数 public string Hello(string name) { Thread ...

  9. c#线程之异步委托begininvoke、invoke、AsyncWaitHandle.WaitOne 、异步回调

    单靠自己看书学总是会走很多弯路,任何人也不列外,有些时候自己遇到的很多问题,其它别人在很久之前也可能遇到过,上网查查可以走很大捷径,对自己的学习有很大帮助,刚开始弄线程这块,一开始只是看书,很多东西都 ...

随机推荐

  1. Indexed DB入门导学(1) – 51CTO.COM

    在html 5中,其中一个引人注意的新特性,那就是允许使用Indexed DB.… 查阅全文 ›

  2. Hadoop中Yarnrunner里面submit Job以及AM生成 至Job处理过程源码解析

    参考 http://blog.csdn.net/caodaoxi/article/details/12970993 Hadoop中Yarnrunner里面submit Job以及AM生成 至Job处理 ...

  3. Qt .pro文件配置大全!

    避免以后的无意义重复劳动,将用过的所有的头文件库文件的配置都放在这里,以后要用的话直接copy就好. eigen3: INCLUDEPATH += \ /usr/local/include/eigen ...

  4. 4.1-4.2 基于HDFS云盘存储系统分析及hadoop发行版本

    一.基于HDFS云盘存储系统 如:某度网盘 优点: *普通的商用机器 内存 磁盘 *数据的安全性 操作: *put   get *rm  mv *java api *filesystem 核心: *H ...

  5. UVaLive 3983 Robotruck (DP + 单调队列)

    题意:有n个垃圾,第i个垃圾坐标为(xi,yi),重量为wi,有一个机器人,要按照编号从小到大的顺序剑气所有的垃圾兵扔进垃圾桶,垃圾桶在原点, 每次总重量不能超过C,两点间距离为曼哈顿距离,求出最短的 ...

  6. POJ - 2312 Battle City BFS+优先队列

    Battle City Many of us had played the game "Battle city" in our childhood, and some people ...

  7. ZOJ3164【区间dp】

     题意: 有n个人,有一种关系叫做8g关系,给出m个关系,给出n个人的阵列 问你最多能拿走多少人,拿走以后相邻就是相邻了 思路: 典型的区间dp: dp[i][j] 代表 i-j 最多能去多少人: 如 ...

  8. css 3d旋转

  9. [Xcode 实际操作]八、网络与多线程-(15)使用网址会话对象URLSession下载图片并存储在沙箱目录中

    目录:[Swift]Xcode实际操作 本文将演示如何通过网址会话对象URLSession下载图片并存储在沙箱目录中. 网址会话对象URLSession具有在后台上传和下载.暂停和恢复网络操作.丰富的 ...

  10. [Xcode 实际操作]九、实用进阶-(28)在iTunes Connect(苹果商店的管理后台)中创建一个新的新的APP

    目录:[Swift]Xcode实际操作 本文将演示如何在iTunes Connect(苹果商店的管理后台)中创建一个新的新的APP. 首先要做的是打开浏览器,并进入[iTunesConnect网站], ...