博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
进程之进程创建的两种方式,两种传值的方式,验证进程间数据隔离,join,守护进程,僵尸进程,孤儿进程...
阅读量:5883 次
发布时间:2019-06-19

本文共 1223 字,大约阅读时间需要 4 分钟。

import osimport timefrom multiprocessing import Processglobal_num=100 #全局变量def func (name,age):    print('子进程name,age:',name,age)    print('子进程ID:',os.getpid())    global global_num    global_num=0    print('子进程global:',global_num)class myProcess(Process):    def __init__(self,name,age):        super().__init__()        self.name=name        self.age=age    def run(self):#start最后调用run方法        print('子进程id',os.getpid())if __name__ == '__main__':    p1=Process(target=func,args=('chuxi',18))#创建进程的第一种方法,传值的第一种方法    p1.start()    p1.join()  # 主进程等待p1子进程运行完在运行,阻塞    print('p1子进程的id:',p1.pid)    p2 = Process(target=func, kwargs={'name': 'chuxi', 'age': 18})#传值的第二种方法    p2.start()    print('主进程的global_num:',global_num)#证明进程之间数据隔离    p2.terminate()#p2进程像操作系统发出关闭指令    time.sleep(1)    print('p2进程是否还存在:',p2.is_alive())    #可以主进程有input,子进程不可以有    lst=[]    for i in range(10):        p4 = Process(target=func, args=('hah', 18))        p4.start()        lst.append(p4)    for el in lst:        el.join()    p3 = myProcess('chuxi', 18)#创建进程的第二种方法    #需要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程     p3.daemon = True  # 把p3进程设置为主进程的守护进程,主程序结束他就跟着结束    p3.start() 

  

 

转载于:https://www.cnblogs.com/PythonMrChu/p/9837577.html

你可能感兴趣的文章
个人作业——软件产品案例分析
查看>>
Java学习:方法重载的使用规则
查看>>
ASP.NET MVC 防止CSRF攻击
查看>>
EF:无法检查模型兼容性,因为数据库不包含模型元数据。
查看>>
0和5
查看>>
C# WinFrom一些技术小结
查看>>
hdu5001 Walk 概率DP
查看>>
模拟select控件&&显示单击的坐标&&用户按下键盘,显示keyCode
查看>>
Mac-OSX下Ruby更新
查看>>
jsp九个内置对象
查看>>
[Python笔记][第一章Python基础]
查看>>
Bloomberg SEP 12.x 迁移小记
查看>>
生日小助手V1.1发布了——拥有更整齐的信息列表
查看>>
代理模式
查看>>
Qt 学习(1)
查看>>
MFC CEdit改变字体大小的方法
查看>>
java 中文数字排序方法
查看>>
centos 关于防火墙的命令
查看>>
openstack 源码分析
查看>>
idea 使用maven plugin tomcat 运行正常,无法进入debug模式
查看>>