标签:模型 效率 有用 http 防止 资源 死锁 利用 切换
并发:单CPU系统中,系统调度在某一时刻只能让一个线程执行,这种调试机制由多种(时间片轮巡为主),通过不断切换线程让其运行叫做并发。
并行:多CPU系统中,可以让两个以上的线程同时进行,这种方式叫做并行。
首先说下多线程出现的原因:
为了解决负载均衡问题,充分利用CPU资源.为了提高CPU的使用率,采用多线程的方式去同时完成几件事情而不互相干扰.为了处理大量的IO操作时或处理的情况需要花费大量的时间等等,比如:读写文件,视频图像的采集,处理,显示,保存等
多线程的好处:
1.使用线程可以把占据时间长的程序中的任务放到后台去处理
2.用户界面更加吸引人,这样比如用户点击了一个按钮去触发某件事件的处理,可以弹出一个进度条来显示处理的进度
3.程序的运行效率可能会提高
4.在一些等待的任务实现上如用户输入,文件读取和网络收发数据等,线程就比较有用了.
多线程的缺点:
1.如果有大量的线程,会影响性能,因为操作系统需要在它们之间切换.
2.更多的线程需要更多的内存空间
3.线程中止需要考虑对程序运行的影响.
4.通常块模型数据是在多个线程间共享的,需要防止线程死锁情况的发生
假设一个服务器完成一项任务所需时间为:T1 创建线程时间,T2 在线程中执行任务的时间,T3 销毁线程时间。
如果:T1 + T3 远大于 T2,则可以采用线程池,以提高服务器性能。
http://blog.csdn.net/syoung99/article/details/52526475
标签:模型 效率 有用 http 防止 资源 死锁 利用 切换
原文地址:http://www.cnblogs.com/XJJD/p/6917652.html