网站大量收购独家精品文档,联系QQ:2885784924

BeginInvoke与EndInvoke方法.doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
开发语言:C#3.0 IDE:Visual Studio 2008 本系列教程主要包括如下内容: 1. ?BeginInvoke和EndInvoke方法 2. ?Thread类 3.?线程池 4.?线程同步基础 5.?死锁 6.?线程同步的7种方法 7.?如何在线程中访问GUI组件 一、线程概述 在操作系统中一个进程至少要包含一个线程,然后,在某些时候需要在同一个进程中同时执行多项任务,或是为了提供程序的性能,将要执行的任务分解成多个子任务执行。这就需要在同一个进程中开启多个线程。我们使用C#编写一个应用程序(控制台或桌面程序都可以),然后运行这个程序,并打开windows任务管理器,这时我们就会看到这个应用程序中所含有的线程数,如下图所示。 如果任务管理器没有“线程数”列,可以【查看】【选择列】来显示“线程计数”列。从上图可以看出,几乎所有的进程都拥有两个以上的线程。从而可以看出,线程是提供应用程序性能的重要手段之一,尤其在多核CPU的机器上尤为明显。 二、用委托(Delegate)的BeginInvoke和EndInvoke方法操作线程 ? 在C#中使用线程的方法很多,使用委托的BeginInvoke和EndInvoke方法就是其中之一。BeginInvoke方法可以使用线程异步地执行委托所指向的方法。然后通过EndInvoke方法获得方法的返回值(EndInvoke方法的返回值就是被调用方法的返回值),或是确定方法已经被成功调用。我们可以通过四种方法从EndInvoke方法来获得返回值。 三、直接使用EndInvoke方法来获得返回值 ??? 当使用BeginInvoke异步调用方法时,如果方法未执行完,EndInvoke方法就会一直阻塞,直到被调用的方法执行完毕。如下面的代码所示: using?System; using?System.Collections.Generic; using?System.Linq; using?System.Text; using?System.Threading; namespace?MyThread { ????class?Program ????{ ????????private?static?int?newTask(int?ms) ????????{ ????????????Console.WriteLine(任务开始); ????????????Thread.Sleep(ms); ????????????Random?random?=?new?Random(); ????????????int?n?=?random.Next(10000); ????????????Console.WriteLine(任务完成); ????????????return?n; ????????} ????????private?delegate?int?NewTaskDelegate(int?ms); ????????????????????? ????????static?void?Main(string[]?args) ????????{ ????????????NewTaskDelegate?task?=?newTask; ????????????IAsyncResult?asyncResult?=?task.BeginInvoke(2000,?null,?null); ??????????? //?EndInvoke方法将被阻塞2秒 ????????????int?result?=?task.EndInvoke(asyncResult);??????????? ????????????Console.WriteLine(result); ????????} ????} } ??? 在运行上面的程序后,由于newTask方法通过Sleep延迟了2秒,因此,程序直到2秒后才输出最终结果(一个随机整数)。如果不调用EndInvoke方法,程序会立即退出,这是由于使用BeginInvoke创建的线程都是后台线程,这种线程一但所有的前台线程都退出后(其中主线程就是一个前台线程),不管后台线程是否执行完毕,都会结束线程,并退出程序。关于前台和后台线程的详细内容,将在后面的部分讲解。 ??? 读者可以使用上面的程序做以下实验。首先在Main方法的开始部分加入如下代码: Thread.Sleep(10000); ??? 以使Main方法延迟10秒钟再执行下面的代码,然后按Ctrl+F5运行程序,并打开企业管理器,观察当前程序的线程数,假设线程数是4,在10秒后,线程数会增至5,这是因为调用BeginInvoke方法时会建立一个线程来异步执行newTask方法,因此,线程会增加一个。 四、使用

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档