day31
http://www.cnblogs.com/yuanchenqi/articles/5745958.html
由于GIL的存在,python中的多线程其实并不是真正的多线程,如果想要充分地使用多核CPU的资源,在python中大部分情况需要使用多进程。Python提供了非常好用的多进程包multiprocessing,只需要定义一个函数,Python会完成其他所有事情。借助这个包,可以轻松完成从单进程到并发执行的转换。
多进程
1 from multiprocessing import Process#进程 2 import time 3 def f(name): 4 time.sleep(1) 5 print('hello', name,time.ctime()) 6 7 if __name__ == '__main__': 8 p_list=[] 9 for i in range(3):#和threading,差不多 10 p = Process(target=f, args=('alvin',)) 11 p_list.append(p) 12 p.start() 13 for i in p_list: 14 p.join() 15 print('end') 16 17 #延迟一秒后全部输出
延迟1面。输出。
执行结果:
/home/nizhipeng/PycharmProjects/learnPython/venv/bin/python /home/nizhipeng/PycharmProjects/learnPython/week8/多进程.py hello alvin Mon Nov 5 22:25:45 2018 hello alvin Mon Nov 5 22:25:45 2018 hello alvin Mon Nov 5 22:25:45 2018 end Process finished with exit code 0
类式调用多线程
1 from multiprocessing import Process 2 import time 3 4 class MyProcess(Process):#继承 5 def __init__(self): 6 super(MyProcess, self).__init__() 7 #self.name = name 可以从新赋值 8 9 def run(self): 10 time.sleep(1) 11 print ('hello', self.name,time.ctime())#hello MyProcess-3 Mon Nov 5 21:20:11 2018 12 13 14 if __name__ == '__main__': 15 p_list=[] 16 for i in range(3): 17 p = MyProcess() 18 p.start() 19 p_list.append(p) 20 21 for p in p_list: 22 p.join() 23 24 print('end')
使用方式和threading多线程一样。
执行结果:
hello MyProcess-1 Mon Nov 5 22:27:51 2018 hello MyProcess-2 Mon Nov 5 22:27:51 2018 hello MyProcess-3 Mon Nov 5 22:27:51 2018 end Process finished with exit code 0
进程关系
1 from multiprocessing import Process 2 import os 3 import time 4 def info(title): 5 print(title)#传入信息 6 print('module name:', __name__)#main 7 print('parent process:', os.getppid())#父进程号 8 print('process id:', os.getpid())#本进程号 9 #每一个进程都有根进程 10 11 def f(name): 12 info('