线程
CPU执行调度的最小单位。
不能独立存在,依赖进程存在。
一个进程至少有一个线程,叫做主线程,另外还有内核线程、用户线程。
线程之间共享内存。
线程之间的通信效率远高于进程间通信效率,线程之间切换代价也比进程小很多。
适用场景
Python的多线程适用于IO密集型任务。
多任务可以由多进程完成,也可以由一个进程内的多线程完成。
关系
进程是由若干线程组成的,一个进程至少有一个线程。
线程是通过一个进程派生出来的,进程结束,其派生的线程就全部死掉了,线程间共用进程的内存,线程奔溃也可能导致进程奔溃。
为什么需要线程锁
多线程和多进程最大的不同在于,多进程中,同一个变量,各自有一份拷贝存在于每个进程中,互不影响,而多线程中,所有变量都由所有线程共享,所以,任何一个变量都可以被任何一个线程修改,因此,线程之间共享数据最大的危险在于多个线程同时改一个变量,把内容给改乱了。
解决方案就是加锁。锁的好处就是确保了某段关键代码只能由一个线程从头到尾完整地执行,坏处当然也很多,首先是阻止了多线程并发执行,包含锁的某段代码实际上只能以单线程模式执行,效率就大大地下降了。其次,由于可以存在多个锁,不同的线程持有不同的锁,并试图获取对方持有的锁时,可能会造成死锁,导致多个线程全部挂起,既不能执行,也无法结束,只能靠操作系统强制终止。
GIL--全局锁
GIL的全称是Global Interpreter Lock (全局解释器锁)。
Python解释器由于设计时有GIL全局锁,导致了多线程无法利用多核。
Python的线程虽然是真正的线程,但解释器执行代码时,有一个GIL锁,任何Python线程执行前,必须先获得GIL锁,然后,每执行100条字节码,解释器就自动释放GIL锁,让别的线程有机会执行。这个GIL全局锁实际上把所有线程的执行代码都给上了锁,所以,多线程在Python中只能交替执行,即使100个线程跑在100核CPU上,也只能用到1个核。
缺陷
频繁线程切换代价高。
线程安全(GIL)。
共享还是独享
如果某些资源不独享会导致线程运行错误,则该资源就由每个线程独享,而其他资源都由进程里面的所有线程共享。
线程共享资源:
地址空间、全局变量、打开的文件、子进程、闹铃、信号与信号服务程序、记账信息。
线程独享资源:
程序计数器、寄存器、栈、状态字。
python的多线程模块
Python的标准库提供了两个模块:thread和threading,thread是低级模块,threading是高级模块,对thread进行了封装。
绝大多数情况下,我们只需要使用threading这个高级模块。
多线程写法
1、导入模块
import threading
2、产生对象,传递的target参数是一个函数,即worker是一个函数;可以给线程传线程的name;可以给线程传参数args,agrs必须是一个元组。
t = threading.Thread(target=worker,name='lyz',args=(1,))
3、执行线程
t.start()
threading 模块提供的方法
threading.currentThread(): 返回当前的线程变量。
threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。
threading.activeCount(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。
run(): 用以表示线程活动的方法。
start():启动线程活动。
join(): 等待至线程中止。join()的作用是,在子线程完成运行之前,这个子线程的父线程将一直被阻塞。
isAlive(): 返回线程是否活动的。
getName(): 返回线程名。
setName(): 设置线程名。
多线程的注意事项
1、线程执行是无序的
2、生命周期:
python中,主线程会等待子线程结束之后才结束。
但是如果设置d.setDaemon(True)这个属性,则主线程结束,子线程就必须结束了。
3、阻塞:
如果你想让主线程等所有子线程执行完才执行主线程的任务:join()
t = threading.Thread(target=worker,name='lyz',args=(1,))
t.join()
4、默认情况下,多线程的无序性,操作全局变量是不安全的,所以有线程锁
from threading import Lock,Thread
然后生成锁对象:
lock = Lock()
申请锁:
lock.acquire()
释放锁:
lock.release()
参考:https://blog.csdn.net/weixin_61805348/article/details/125021831?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-125021831-blog-125350491.235^v43^pc_blog_bottom_relevance_base9&spm=1001.2101.3001.4242.1&utm_relevant_index=3
https://blog.csdn.net/weixin_41777118/article/details/130416802
https://www.cnblogs.com/weiman3389/p/6044940.html
标签:执行,GIL,python,threading,线程,进程,多线程,及锁 From: https://www.cnblogs.com/klb561/p/18050485