1.发展背景
2.进程和线程的区别
- 线程是程序执行的最小单位,而进程是操作系统分配资源的最小单位;
- 一个进程由一个线程组成,线程是一个进程中代码的不同执行路线;
- 进程之间相互独立,但同一进程下的各个线程之间共享程序的内存空间(包括代码段、数据集、堆等)及一些进程级的资源(如打开文件和信号),某进程内的线程在其他进程不可见;
- 调度和切换:线程上下文切换比进程上下文切换要快得多。
总之,线程和进程都是一种抽象的概念,线程是一种比进程更小的抽象,线程和进程都可用于实现并发。
3.单线程
在单线程中,当前处理器需要处理多个任务时,必须对这些任务安排执行顺序,并按照这个顺序来执行任务。假如我们创建了两个任务:听音乐(music)和看电影(movie)。在单线程中,我们只能按先后顺序来执行这两个任务。
# 单线程
import time
def music(name, loop):
for i in range(loop):
print('listen music %s %s'%(name, time.ctime()))
time.sleep(2)
def movie(name, loop):
for i in range(loop):
print('look movie %s %s'%(name, time.ctime()))
time.sleep(2)
if __name__ == '__main__':
music('南街北巷', 3)
movie('大话西游', 4)
执行如下:
01-python的单线程
4.Python的多线程模块
Python中的多线程 ——— Python中存在着多线程,但是python仅仅支持一个线程的运行
Python中的线程是假的,是伪多线程
4.1 Python多线程基本步骤:
4.2 threading使用简介-1
target:指定执行的函数名
args:使用元组方式给指定任务传参
kwargs:使用字典方式给指定任务传参
【 args使用方式 【此处注意,若只有一个元素,那个逗号也是不可以省略的 】】
线程对象 = multiprocessing.Process(target=*, args=(*,))
【 kwargs使用方式 】
线程对象 = multiprocessing.Process(target=*, kwargs={
"变量名": 变量值})
4.2.1 创建多线程【包含args和kwargs参数的使用案例】
'''
线程对象名 = threading.Thread(target=xxx, args=(), kwargs={})
target:指定可调用的任务对象;
args:以元组的形式给可调用的任务对象进行传参;
kwargs:以字典的形式给可调用的任务对象进行传参。
'''
# 多线程
import threading
import time
def music(name, loop):
for i in range(loop):
print('listen music %s %s'%(name, time.ctime()))
time.sleep(2)
def movie(name, loop):
for i in range<