声明:参考B站自学成长记录
https://www.bilibili.com
进程 / 线程概念
进程:(Process)
是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础
线程:(thread)
是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位
一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务
代码示例
# coding=utf-8
from threading import Thread
from multiprocessing import Process
import time
def t_run(): # 线程函数
time.sleep(1)
def threed_console(num):
"""
多线程示例
:param num: 表示启动多少个线程
:return: None
"""
t_list = [] # 线程列表:存放多个已启动的线程
t_s_time = time.time() # num个线程运行开始时间
for i in range(num): # 循环创建num个线程
t = Thread(target=t_run,) # 创建线程
t.start() # 启动线程
t_list.append(t) # 将启动的线程添加到 线程列表
[tt.join() for tt in t_list] # join方法让主线程等待所有子线程结束后, 主线程再结束
t_e_time = time.time() # num个线程运行结束时间
# 统计运行结果
print("{}个线程总耗时:{:.2f}s".format(num, t_e_time - t_s_time))
def p_run(): # 进程函数
time.sleep(1)
def process_console(num):
"""
多进程示例
:param num: 表示启动多少个进程
:return: None
"""
p_list = [] # 进程列表,存放多个已启动的进程
p_s_time = time.time() # num个进程运行开始时间
for i in range(num): # 循环启动num个线程
p = Process(target=p_run,) # 创建进程
p.start() # 启动进程
p_list.append(p) # 将启动的进程添加到 进程列表
[pp.join() for pp in p_list] # join方法让主进程等待所有子进程结束后, 主进程再结束
p_e_time = time.time() # # num个进程运行结束时间
# 统计运行结果
print("{}个进程总耗时:{:.2f}s".format(num, p_e_time - p_s_time))
if __name__ == '__main__':
threed_console(5)
process_console(5)
运行结果