本篇主要讲的是多线程和多进程的一些基础知识,包括并发、并行、进程、线程相关概念以及线程的创建与调用、阻塞线程和守护线程的相关实例操作。希望感兴趣的小伙伴可以坚持看下去同时欢迎提出宝贵的意见让我们一起进步!
01:并发和并行
1)并发:逻辑上具备同时处理多个任务的能力。
① 特 点:侧重多个任务交替执行,而多个任务之间有可能还是串行的
② 举 例:比如一个人一把铁锹同时挖三个坑
2)并行:物理上在同一时刻执行多个并发任务。
① 特 点:侧重同时执行
② 举 例:比如三个人三把铁锹同时挖三个坑
02:进程和线程
1)进程:运行某个软件就相当于开了一个进程,比如开一个QQ就相当于开了一个进程。
2)线程:在QQ这个进程里,传输文字开一个线程,传语音开一个线程等。
3)注意:一个进程管着多个线程,一个进程有且至少有一个线程
03:线程的创建与调用
1)Thread方法:创建一个线程并且返回线程实例
①target值:线程要运行的函数
②arges为参数,通过列表和元组来传参。需要注意元组传参如果只有一个元素需要加逗号
2)启动线程实例:线程实例.start
3)获取线程名:线程实例.getName
4)注意事项:
①函数和变量是一样,在python中都是对象。函数可以当参数、当返回值、可以赋值给其他变量
②函数作为一个参数传递时,不可以加括号。因为加括号表示执行这个函数,而传参只是使用函数名。
import time,threading
def foo(something):#定义每个线程要运行的函数
for i in range(3):
time.sleep(1)#休眠1s来模拟CPU处理很多事情
print('CPU正在执行:'+something)
def bar(something):
for i in range(5):
time.sleep(1)
print('CPU正在执行:'+something)
t1=threading.Thread(target=foo,args=['看电影'])#生成一个线程实例
t2=threading.Thread(target=bar,args=['听音乐'])
t1.start()#启动线程实例
t2.start()
#总共3个进程:一个主线程(该python文件)+2个子线程
print(t1.getName())#获取线程名
print(t2.getName())
print(threading.main_thread().getName())
03:阻塞主线程(join)
主线程等待子线程结束后再运行
import time,threading
def foo(something):#定义每个线程要运行的函数
for i in range(3):
time.sleep(1)#休眠1s来模拟CPU处理很多事情
print('CPU正在执行:'+something)
def bar(something):
for i in range(5):
time.sleep(1)
print('CPU正在执行:'+something)
t1=threading.Thread(target=foo,args=['看电影'])#生成一个线程实例
t2=threading.Thread(target=bar,args=['听音乐'])
t1.start()#启动线程实例
t2.start()
t1.join()#阻塞主线程,检查t1线程是否执行结束
print(t1.getName())
print(t2.getName())
05:守护线程(setDaemon)
1) 方法特点:与join方法基本相反,必须在start()方法调用之前设置
2)使用场景:主线程完成后,不管子线程是否完成都要和主线程一起退出
3)注意事项:设置守护线程后,主线程不结束子线程也不会结束
#需求:电影结束后音乐自动结束
import time,threading
def foo():
while True:
time.sleep(1)
print('听音乐')
t1=threading.Thread(target=foo)
t1.setDaemon(True)#守护线程:主线程结束子线程也结束
t1.start()
for i in range(3):
time.sleep(1)
print('看电影')
print('电影放映结束!')