基本介绍:
线程是程序执行的最小单位,进程负责分配资源,线程使用这些资源执行相关程序,也就是说进程是线程的容器,一个进程中最少有一个线程来负责执行程序。线程自身不拥有系统资源,只占用一些运行过程中必要的资源,可以与同属于一个进程的其他线程来共享进程所拥有的全部资源。例如:通过一个QQ软件(一个进程)打开两个窗口(两个线程)跟两个人聊天,实现多任务的同时又节省了系统资源。
作用:
有了进程才会有线程,一个进程中可以包含一个或者多个线程。
哔哩哔哩弹幕大佬解释:
创建步骤
1、简单步骤
2、详细参数介绍
1)线程的创建与启动代码
2)线程执行有参数的任务
示例:
注意以元组方式传参的时候,如果只有一个参数,不要漏写 , 逗号。
以kwargs字典方式传参的时候参数顺序需要与函数参数的顺序一致。
3)注意事项
1、主线程会等待所有子线程执行结束再结束
import time
import threading
def work():
# 此函数会执行 2s
for i in range(10):
print("工作 ...")
time.sleep(0.2)
if __name__ == "__main__":
sub_thread = threading.Thread(target=work)
sub_thread.start()
# 主线程等待1s后结束
time.sleep(1)
print("主线程结束了...")
运行效果演示:
2、设置守护线程(主线程结束,子线程自动销毁)
注意一定要在线程启动之前设置守护才会起到作用。
3、线程间的执行顺序
线程的执行顺序与线程的创建顺序无关,与CPU的调度有关,因此通常说是无序的,但可以通过获取线程的信息,来查看线程的顺序。
获取当前线程的信息:
多线程之间的执行是无序的*****
进程和线程的对比
1)关系对比
2)区别对比
3)优缺点对比
信号量
# python多线程的信号量,管理一个计数器,该计数器由每个acquire()调用递减(当前被占用),并由每个release()调用递增(解除占用)。
# 计数器永远不会低于零,当acquire()发现计数器为零时,线程阻塞,等待其他线程调用release()。