进程的介绍
进程的概念
进程和子进程
程序运行的时候会默认创建一个进程,如果在程序运行后又创建了的就叫子进程。
多进程的好处
程序可以并发执行,提高效率。
py中的多进程
操作步骤
传参
获取进程编号
os.getpid() # 获取当前进程编号
os.getppid() # 获取父进程的编号
主进程和子进程的退出关系——守护进程
主进程任务结束完,会等待所有子进程结束才会退出。
如何实现主进程任务结束完 直接退出? ——守护进程
主进程的子进程如果都是守护进程,当主进程可以退出时,所有的子进程都会自动关闭
py实现:
import multiprocessing
import os
import time
def dosomgting(eve ):
for i in range(3):
print(eve,os.getpid())
time.sleep(1)
if __name__ == '__main__':
print("fatherfather" , os.getppid())
# print("father" , os.getpid())
a = multiprocessing.Process(target=dosomgting, args=("跳舞",)) # 用元组方式传参
b = multiprocessing.Process(target=dosomgting, kwargs={"eve": "练武术"}) # 用字典方式传参
a.daemon =True # 设置守护进程
b.daemon =True
a.start()
b.start()
print("主进程完成了!!! 退了")
简单demo代码
- 无参数调用
import multiprocessing
import time
def dance():
for i in range(3):
print("跳舞")
time.sleep(0.5)
def sing():
for i in range(3):
print("唱歌")
time.sleep(0.5)
if __name__ == '__main__':
multiprocessing.Process(target=dance).start()
multiprocessing.Process(target=sing).start()
- 两种传参调用(元组必须按顺序,字典对应的参数名必须要严格对应)
import multiprocessing
import time
def dosomgting(eve):
for i in range(3):
print(eve)
time.sleep(1)
if __name__ == '__main__':
multiprocessing.Process(target=dosomgting, args=("跳舞",)).start() # 用元组方式传参
multiprocessing.Process(target=dosomgting, kwargs={"eve": "练武术"}).start() # 用字典方式传参
线程
为什么使用多线程
*进程是线程的容器,一个进程下至少有一个线程。
创建方式
- 普通创建
- 带参数创建
其余内容和进程差不多,也能设置守护
进程线程比较