码迷,mamicode.com
首页 > 编程语言 > 详细

多线程,多进程使用场景

时间:2017-12-19 15:17:12      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:关键字   运算   物理   保存   bsp   关系   需要   使用场景   功能   

既然有GIL锁,为什么还使用多线程?

      CPU运行程序的时候,从内存中读取数据块,但是内存不支持断电保存的功能。一旦断电,数据就会丢失。所以需要把数据存到物理磁盘中,所以CPU运行程序的时候需要先从磁盘中读出来,放到内存中,CPU才能取到数据。磁盘的读取比较慢,CPU在物理磁盘中取数据时,需要等待磁盘准备数据,什么时候数据准备好了,CPU才能使用数据,这样造成了资源的浪费,写数据是一样的,当CPU往磁盘写入数据的时候就会等待,等数据存入到磁盘中了CPU才能执行别的程序。造成了CPU空闲阻塞状态,如果有大量的IO操作,就会频繁出现阻塞行为,那么GIL锁就会自动被释放,这样就会保证多线程同时运行的效果,虽然不是全部的。一跳主线运行的时候,大概运行了100条指令的时候就会释放GIL锁,或者出现阻塞的时候就会释放GIL锁。

多线程的应用场景:

        CPU密集型的程序,整个程序运行中过程中不需要等待任何的IO操作,只有大量的CPU进行运算,这种线程不合适,进程实现更加合适,因为每个进程中都有一个线程,独享一个GIL锁,这样就不涉及抢的问题了,各自运行各自的程序。所以进程实现更加合适、

协程的使用场景:

        协程内部是线程内容划分的更小的单位,协程跟操作系统没有关系,只是程序员自己划分出来的,类似于一个线程中的一跳主线中的两个函数交替运行,达到同时运行的效果,用yield关键字可以让函数暂停下来,next()函数可以让程序继续运行,互相配合达到了协程的效果,上下文切换快速,不需要竞争资源,一条主线。

 

多线程,多进程使用场景

标签:关键字   运算   物理   保存   bsp   关系   需要   使用场景   功能   

原文地址:http://www.cnblogs.com/zhangshuyang/p/8064899.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!