复习
1.同步、异步、阻塞、非阻塞
同步:所谓同步就是一个任务的完成需要依赖另外一个任务时,只有等待被依赖的任务完成后,依赖的任务才能算完成,这是一种可靠的任务序列
异步:所谓异步是不需要等待被依赖的任务完成,只是通知被依赖的任务要完成什么工作,依赖的任务也立即执行,只要自己完成了整个任务就算完成了。至于被依赖的任务最终是否真正完成,依赖它的任务无法确定,所以它是不可靠的任务序列。
阻塞:等待者除了等待消息通知之外不能做其它的事情,那么该机制就是阻塞的,表现在程序中,也就是该程序一直阻塞在该函数调用处不能继续往下执行。
非阻塞:因为他(等待者)没有阻塞在这个消息通知上,而是一边做自己的事情一边等待。
学习内容
1.进程的生命周期
1.代码执行结束,进程结束
2.主进程结束而子进程未结束,则主进程等待子进程结束再结束
3.子进程的存在不一定依赖父进程
代码区
1.起多进程
from multiprocessing importProcessimportosdeffunc(args):print(args)print('子进程: %s'%os.getpid())print('子进程的父进程: %s' %os.getppid())print(123)if __name__ == '__main__':
p= Process(target=func, args=('sd',)) #注册
#p是一个进程对象,未启动
p.start() #开启子进程
print('父进程: %s' %os.getpid())print('父进程的父进程: %s' %os.getppid())print('*'*10)
2.多进程的join方法
from multiprocessing importProcessimporttimedeffunc(arg1,arg2):print('*'*arg1)
time.sleep(5)print('*'*arg2)if __name__ == '__main__':
p= Process(target=func, args=(10, 20))
p.start()
p.join()#感知一个子进程的结束,将异步改为同步
print('=====:运行完了')
3.多进程合并
from multiprocessing importProcessimporttimedeffunc(arg1,arg2):print('*'*arg1)
time.sleep(5)print('*'*arg2)if __name__ == '__main__':
p_lst=[]for i in range(10):
p1= Process(target=func, args=(10*i, 20*i))
p_lst.append(p1)
p1.start()
[p1.join()for p1 inp_lst]print('yuncing')
4.面向对象调多进程
from multiprocessing importProcessimportosclassMyProcess(Process):def __init__(self,arg1):
super().__init__()
self.arg1=arg1defrun(self):print(self.name)print(self.pid)print(self.arg1, '参数')print(os.getpid())if __name__ == '__main__':print('主进程:', os.getpid())
p1= MyProcess(1)
p1.start()
p2= MyProcess(1)
p2.start()
5.进程间数据隔离
from multiprocessing importProcessimportosdeffunc():globaln
n=0print('pid: %s'%os.getpid(), n)if __name__ == '__main__':
n= 100p= Process(target=func)
p.start()
p.join()print(os.getpid(),n)
6.守护进程——随着主程序的代码执行完毕而结束
from multiprocessing importProcessimporttimedeffunc():while 1:
time.sleep(1)print('copy that')#def func():#print()
if __name__ == '__main__':
p= Process(target=func)#p.daemon = True
p.start()
i=0while i < 3:print('i am socketserver')
time.sleep(5)
i+= 1
print(i)
7.买车票——程序锁
from multiprocessing importProcessimportjsonimporttimefrom multiprocessing importLockdefshow(i):
with open('ticket') as f:
dic=json.load(f)print('余票:%s'%dic['ticket'])defbuy_ticket(i,lock):
lock.acquire()
with open('ticket') as f:
dic=json.load(f)
time.sleep(0.1)if dic['ticket'] >0:
dic['ticket'] -= 1
print('\033[32m %s OK!!!\033[0m'%i)else:print('\033[31m %s NO!!!\033[0m'%i)
time.sleep(0.1)
with open('ticket','w') as f:
json.dump(dic,f)
lock.release()if __name__ == '__main__':for i in range(10):
p= Process(target=show,args=(i,))
p.start()
lock=Lock()for i in range(10):
p= Process(target=buy_ticket,args=(i,lock))
p.start()