赞
踩
在多任务处理中,我们既可以使用多进程,也可以使用多线程。但多进程和多线程并不是随意选择的,因为它们应对的场景不同,优缺点也不同。
多进程就是在程序中创建多个子进程来执行不同的分支。
多进程的优点:
多进程的缺点:
多线程是在进程中划分多个执行流,每个执行流是一个线程。
多线程优点:
多线程缺点:
介绍两种适合使用多执行流的场景:CPU密集型程序、IO密集型程序。
CPU密集型程序:
(1)CPU密集是指程序对CPU的依赖程度很高,这说明程序中大部分都是数据处理,因为CPU就是用来运算的。
(2)现在的计算机基本都是多核,所以如果将一个CPU密集型程序分为多个执行流,让每个核心执行一条执行流,那么将会大大提升数据的运算速率。
(3)但执行流并不是越多越好,因为程序是切换调度运行的,太多的执行流意味着要经常进行调度,成本就太高了,因此要找一个合适的执行流数量。
IO密集型程序:
(1)IO密集型程序是指程序对IO设备的依赖度很高,具有非常多的IO操作。
(2)IO操作包含两部分:IO等待,数据拷贝。IO等待就是程序要等待IO设备资源空闲才可以使用,数据拷贝就是IO数据的操作。
(3)CPU的处理速度很快,但IO数据的处理是从硬盘读取或写入的,速度上远远比不过CPU处理的速度,因此IO操作中耗费时间最多的步骤其实是等待IO设备。
(4)如果只有一个执行流,假如有两个IO请求,一个A程序,一个B程序,这两个程序要使用同一个IO设备,那么就需要排队。
(5)排队时首先进行A程序的两个阶段,然后进行B程序的两个阶段。如图:
(6)如果有两个执行流,那么两个程序就可以同时进行IO等待,这样就能减少总体的运行时间。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。