一. 多任务
概念:同一时间执行多个任务 表现形式 并发:任务数量大于CPU核心数,任务交替执行(单核CPU一定是并发) 并行:任务数量小于或等于CPU核心
二. 进程 2.1概念
进程是资源分配的最小单位,他是操作系统进行资源分配和调度运行的基本单位。一个正在运行的一个程序就是一个进程。
2.2 创建步骤
import multiprocessing
进程对象 = multiprocessing.Process(target=任务名)
进程对象.start()
2.3 带有参数的进程 两种方式
args:以元祖方式传参。元组传参一定要和参数顺序一致,特别注意元组内只有一个元素时需要加上逗号。 kwargs:以字典方式传参。以字典传参时字典的key要和参数名一致。
2.4 例程
import multiprocessing
import time
def sing(name,num):
for i in range(num):
print("%s正在唱歌~~~"%name)
time.sleep(0.5)
def dance(name,num):
for i in range(num):
print("%s正在跳舞~~~"%name)
time.sleep(0.5)
if __name__ == '__main__':
s1 = multiprocessing.Process(target=sing, args=('小明', 3))
d1 = multiprocessing.Process(target=dance, kwargs={"num": 4,"name": "小美"})
s1.start()
d1.start(
2.5 获取进程编号
获取当前进程编号
os.getpid()
获取当前父进程编号
os.getppid()
注:
1.主进程会等待所以子进程执行结束再结束 2.如果设置守护主进程,则主进程退出子进程销毁,主进程不再等待子进程去执行
if __name__ == '__main__':
work_process = multiprocessing.Process(target=work)
work_process.daemon = True
work_process.start()
time.sleep(1)
print("主进程执行结束")
|