1.并发的概念python基础
举个例子:
1.1并发与并行
并发:逻辑上具备同时处理多个任务的能力
并行: 物理上在同一时刻执行多个并发任务
1.2什么是线程,什么是进程
开个QQ,开了一个进程;开了迅雷,开了一个进程
在QQ的这个进程里,传输文字开一个线程、传输语音开了一个线程、弹出对话框又开了一个线程
所以运行某个软件,相当于开了一个进程。在这个软件运行的过程里(在这个进程里),多个工作同时运转,完成了QQ的运行,那么这“多个工作”分别有一个线程,所以一个进程管着多个线程,一个进程有且至少有一个线程
线程与进程的区别(了解)
- 线程共享创建它的进程的地址空间;进程有自己的地址空间。
- 线程可以直接访问其进程的数据段;进程有它们自己的父进程的数据段副本。
- 线程可以直接与进程中的其他线程通信:进程必须使用进程间通信来与兄弟进程通信。
- 容易创建新线程;新进程需要父进程的复制。
- 线程可以对同一进程的线程进行相当大的控制;流程只能对子流程进行控制
- 对主线程的更改(取消、优先级更改等)可能会影响进程中其他线程的行为;对父线程的更改不会影响子进程。
2.python线程代码实操
2.1创建线程
# -*- coding: utf-8 -*-
# @File : 可删1.py
# @Time : 2024/6/17 15:29
# @Author : syq
# @Email : 1721169065@qq.com
# @Software: PyCharm
import threading
import time
def foo(something):
for i in range(10):
# time.sleep(1)
print(something)
#创建线程 target=foo 其中foo是作为参数传递,不用带()
#Thread是一个类
t1=threading.Thread(target=foo,args=("看电影",))
t2=threading.Thread(target=foo,args=("听音乐",))
#启动线程
t1.start()
t2.start()
2.2.join函数
# -*- coding: utf-8 -*-
# @File : 可删1.py
# @Time : 2024/6/17 15:29
# @Author : syq
# @Email : 1721169065@qq.com
# @Software: PyCharm
import threading
import time
def foo(something):
for i in range(10):
# time.sleep(1)
print(something)
#创建线程 target=foo 其中foo是作为参数传递,不用带()
#Thread是一个类
t1=threading.Thread(target=foo,args=("看电影",))
t2=threading.Thread(target=foo,args=("听音乐",))
#启动线程
t1.start()
t2.start()
#join在子线程完成运行之前,这个子线程的父线程将一直被阻塞
t1.join()
t2.join()
print("启动数据检查...") #即t1和t2线程要都运行结束,才会运行该行
2.3守护线程
# -*- coding: utf-8 -*-
# @File : 可删1.py
# @Time : 2024/6/17 15:29
# @Author : syq
# @Email : 1721169065@qq.com
# @Software: PyCharm
import threading
import time
def foo(something):
for i in range(10):
time.sleep(1)
print(something)
#创建线程 target=foo 其中foo是作为参数传递,不用带()
#Thread是一个类
t1=threading.Thread(target=foo,args=("看电影",))
t2=threading.Thread(target=foo,args=("听音乐",))
#声明守护线程程,必须在start调用之前申明守护线程
t1.setDaemon(True)
t2.setDaemon(True)
#启动线程
t1.start()
t2.start()
for i in range(5):
time.sleep(1)
print("消费数据")
print("消费需求已经满足了") #打印完这句话后,其他线程就算没有结束,也不会再运行了