python中多线程与多进程的选择问题

多线程与多进程的选择问题

既然python中多线程和多进程都能够进行异步操作,那么到底应该如何选择

首先我们必须知道GIL全局解释锁对线程的影响,其同一时间只能够允许一个线程进入cpu进行执行,因此对于cpu密集型的程序并不适用于多线程操作

cpu密集型的功能对cpu的占用率要求很高,需要大量的运算能力,而我们采用多进程的话实际上cpu适用受到了限制,因此这种功能需要用多进程,多进程则不会因为全局解释锁而受到影响

当我们进程io密集型的操作,io密集型对cpu的占用并不大,实际占用大的是对硬盘和内存的读写操作,比如爬虫,爬虫用的最多的是爬取数据,将数据返回回来之后进行处理过程实际上占用到的整个程序执行时间是比较少的,所以这种io密集型的使用多线程,避免cpu的浪费

猜你喜欢

转载自blog.csdn.net/weixin_43959953/article/details/84899267
今日推荐