python-中高级-线程进程

无论是什么语言的代码,它最终都是转到CPU下面执行。除了CPU任何东西都不具备执行代码的能力。解释器只是翻译(相当于中介),python中的解释器是Cpython(python是用C写的)。只有操作系统才能调动CPU。其实线程就是一堆一堆的指令,使OS去调动CPU。一个线程就是一堆指令集合。早年的CPU是一核的,多核CPU是近几年才发展起来的。一边看电影一边听音乐,执行的时候是竞争执行的,CPU会不断地切换,这个切换的时间是非常快的,用户根本感觉不到这种切换。如果执行过程中遇到 IO 阻塞(sleap(时间)这个也先当于IO阻塞)),CPU就会停止,去执行别的,等待它要执行时再回来执行。有多线程切换,有IO阻塞的,CUP就会执行别的,而不是在那里闲着。这样就可以充分利用CUP起来。


进程和线程不同,进程不是代码了,它是一堆资源的整合,进程里面可以有多个线程,是对资源管理的一个集合。如QQ就是一个进程。线程可以资源共享的,进程是不可以的,像QQ的信息360是接收不到的,360也不能与QQ进行通信,每一个应用软件都是独立的,不共享资源的(指的是应用软件内部的资源共享)。QQ是一个进程,它内部有很多线程。线程和进程没有快慢可比,都是一样的,线程执行的时候,进程也执行,都是执行一堆相同的东西。

python中处理IO密集型,用多线程还是可以的,但是处理计算密集型,多线程就不可以了。python不能调用多核的CPU,它时不能同时执行多线程的。要想执行计算密集型的多线程,可以用多进程搭载多线程执行,但是这个方案是不完美的(历史遗留的问题只能是这样解决)。

能让操作系统工作起来的就是线程。

因为GIL的存在,python不能真正地实行多线程(即多核)
















线程是竞争式地抢占资源的。线程之间数据时可以共享,交换。进程不可以


















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值