(一)线程--简述线程概述及原理

线程是程序执行的基本原子单位. 一个进程可以由多个线程组成.
在分布式编程中,正确使用线程能够很好的提高应用程序的性能及运行效率.

实现原理是将一个进程分成多个线程,然后让它们并发异步执行,来提高运行效率.

并发执行并不是同时执行(占有CPU),任意时刻还是只能有一个线程占用CPU,
只不过是它们争夺CPU频繁一些,感觉到他们似乎都在运行.

下面通过一个简单的例子来说明一下它的工作原理

设一个进程要完成两个任务:任务1和任务2
 并且任务1要经历: A1->B1->C1三个步骤才能完成
     任务2要经历: A2->B2->C2三个步骤才能完成
  I.如果两个任务同步执行的话完成两个任务是这样执行的:
   
    花费时间段:   1   2   3   4   5  6
                 A1->B1->C1->A2->B2-C2
   
     这样从A1一直到c2只能一个一个地执行. 当A1占用CPU执行时,从B1到C2线程只能在等待. 
     甚至它们不相互竞争同一个资源时,也要等待前面的执行完成,自己才能执行


  II.如果两个任务异步执行的话完成两个任务是这样执行的:
  
    花费时间段:   1   2   3   4   5  6   
                  A1->B1->C1
                  A2->B2->C2
   
     这样,任务1和任务2就分成两个独立的执行对象.  也就是说:
     A1->B1->C1 和 A2->B2->C2 是并发执行的. 当A1在执行某个运算时,A2线程可以去做其它
     的一些事情,比如访问磁盘等外部设备等

      对比一下I和II两种执行方式,完成所有任务I需要6个时间段,
  而II只需要3个时间段就完成了(事实上会多一点,因为方式II中的线程轮询CPU比较频繁,在轮询CPU时会花费一些时间);方式II所需时间是I的一半. 所以II完成整个任务要快.
      另一方面,II执行方式,完成每个任务所需的时间可能会花费时间长些,因为I方式是各个线程依次占用CPU执行,当A1占用CPU时,CPU就只为A1服务,当A1执行完后,才让出CPU。II情况就不一样了,它们是异步执行的,轮流使用CPU频繁,经常让出或占有CPU,执行每个线程完成的时间也就会相对长些.

    一般情况下,如果多个线程在执行时都要抢占某一个资源或某几个资源,则最好不用异步线程执行.因为它们是并发执行,很可能同时争夺某个资源有CPU,这时要么执行资源分配算法(比如要判断哪个线程优先级高,这要花费时间),或者是按时间片算法(这样要付出 轮询CUP/交接/让出CPU 所需的时间).  如果多个线程所需要的系统资源是比较均匀的,这时完全可以让它们异步并发执行,比如: 当一个线程在给客户端
发出消息后,并不是一直在等待此客户端回应,它可以继续处理下一个客户端请求.  

 

相关线程知识文章资源:

http://www.microsoft.com/china/msdn/archives/library/dv_vstechart/html/vbtchAsyncProcVB.asp
http://dev.yesky.com/msdn/403/2114403.shtml
http://www.host01.com/Get/Net/00020001/0561614361718389.htm
http://industry.ccidnet.com/art/294/20030528/47645_1.html
http://www.5ivb.net/Info/94/Info29313/
http://cnbie.net/print_146048m49081.html
http://www.yesky.com/463/1704463.shtml
http://www.pconline.com.cn/pcedu/empolder/net/cs/0507/655844.html
http://www.vchome.net/dotnet/dotnetdocs/dotnet1.htms
http://www.ddvip.net/program/c-/index1/25.htm

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值