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

Visual Basic.NET程序设计教程 陈语林 p10新.pptVIP

Visual Basic.NET程序设计教程 陈语林 p10新.ppt

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第十章 多线程应用程序的开发 .NET框架的一个新特性就是,它包含了一个标准的创建自由线程应用程序的方法。 支持建立自由线程(free-threaded)的应用。自由线程允许Visual Basic.NET应用程序同时独立执行多个任务,因而提高了应用程序的性能和灵敏性。 10.1 进程和线程 每个运行的Windows应用程序都有一个进程,它在逻辑上代表了这个应用程序的地址空间,DLL可以加载到这个空间里,变量也可以存储在这里。要完成任何工作,一个进程必须有一个执行的路径,或者说线程。 自由线程(free threaded)允许Visual Basic.NET应用程序同时独立执行多个任务,因而提高了应用程序的性能和灵敏性。 .NET框架中包含的System.Threading命名空间专门负责实现多线程功能,而且操作相当简单,只需要利用System.Threading命名空间中的Thread类,就具有了实现自由线程的属性和方法。 Thread类的每一个实例都代表了应用程序进程空间里一个不同的线程。 10.2 多线程应用程序 【例10-1】多线程的应用程序示例。 10.2.1 如何创建一个新线程 要实现多线程必须引用命名空间System.Threading,因此,先输入下列代码: Imports System.Threading 一个无限循环的代码如下: Private Sub BackgroundProcess( ) Dim i As Integer=1 Do while True ProgressBar1.Value=i i+=1 If i =10000 Then i =1 Loop End Sub 下面的代码声明了一个新的线程,并启动它: Dim t1 As Thread t1=New Thread (AddressOf Me.BackgroundProcess) 10.2.2 控制线程 如果你想让数据处理的速度变慢,可以在其中放入一个sleep方法的调用,代码如下: Private Sub BackgroundProcess( ) Dim i As Integer=1 Do While True ProgressBar1.Value=i i+=1 If i= 10000 Then i=1 Thread.CurrentThread.Sleep(10) Loop End Sub 10.2.3 线程的生存期 线程启动后,发生下列事件线程将终止: 它运行的方法执行完毕。 包含线程的过程终止。 在线程对象上调用Abort方法。 在上面的示例中,它是一个无限的循环,因此必须调用Thread.Abort方法,向程序中添加如下代码: t1.Abort( ) Public Class Form1 Inherits System.Windows.Forms.Form Dim t1 As Thread Dim t2 As Thread Private Sub BackgroundProcess() Dim i As Integer = 1 Do While True ProgressBar1.Value = i i += 1 If i = 10000 Then i = 1 Loop Thread.Sleep(1) End Sub Private Sub ReceiveDataProcess() Dim i As Integer = 1 Do While True ProgressBar2.Value = i i += 1 If i = 10000 Then i = 1 Loop End Sub Private Sub ButtonBackProc_Click(ByVal Sender As System.Object,ByVal e As System.EventArgs) Handles ButtonBackProc.Click t1 = New Thread(Address

文档评论(0)

精品课件 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档