进程之进程创建的两种方式,两种传值的方式,验证进程间数据隔离,join,守护进程,僵尸进程,孤儿进程

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import os
import time
from multiprocessing import Process
global_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进程设置为主进程的守护进程,主程序结束他就跟着结束<br>   p3.start() 

  

 

posted @   冒蓝火的加特林哒哒哒  阅读(155)  评论(0编辑  收藏  举报
编辑推荐:
· ASP.NET Core 模型验证消息的本地化新姿势
· 对象命名为何需要避免'-er'和'-or'后缀
· SQL Server如何跟踪自动统计信息更新?
· AI与.NET技术实操系列:使用Catalyst进行自然语言处理
· 分享一个我遇到过的“量子力学”级别的BUG。
阅读排行:
· dotnet 源代码生成器分析器入门
· 官方的 MCP C# SDK:csharp-sdk
· [WPF] 在RichTextBox中输出Microsoft.Extension.Logging库的
· 一款 .NET 开源、功能强大的远程连接管理工具,支持 RDP、VNC、SSH 等多种主流协议!
· 一步一步教你部署ktransformers,大内存单显卡用上Deepseek-R1
点击右上角即可分享
微信分享提示