zoukankan      html  css  js  c++  java
  • 守护进程(了解)

    守护进程

    主进程创建子进程,然后将该进程设置成守护自己的进程,守护进程伴随着子进程的结束而结束。

    如果我们有两个任务需要并发执行,那么开一个主进程和一个子进程分别去执行就ok了,如果子进程的任务在主进程任务结束后就没有存在的必要了,那么该子进程应该在开启就被设置成守护进程。主进程代码运行结束,守护进程随即终止

    关于守护进程需要强调两点:

    其一:守护进程会在主进程代码执行结束后就终止

    其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic processes are not allowed to have children

    from multiprocessing import Process
    import time
    
    
    def task(name):
        print("%s is running" % name)
        time.sleep(2)
        # p = Process(target=time.sleep, args=(3,))    # 守护进程不能再有子进程
        # p.start()
    
    
    if __name__ == "__main__":
        p = Process(target=task, args=("子进程1", ))
        p.daemon = True  # 守护进程 一定要在p.start()前设置,设置p为守护进程,禁止p创建子进程,并且父进程代码执行结束,p即终止运行
        p.start()
    
        p.join()
        print("主")   # 只要终端打印出这一行内容,那么守护进程p也就跟着结束掉了
    

      


    练习题

    思考下列代码的执行结果有可能有哪些情况?为什么?

    from multiprocessing import Process
    
    import time
    def foo():
        print(123)
        time.sleep(1)
        print("end123")
    
    def bar():
        print(456)
        time.sleep(3)
        print("end456")
    
    if __name__ == '__main__':
        p1=Process(target=foo)
        p2=Process(target=bar)
    
        p1.daemon=True
        p1.start()
        p2.start()
        print("main-------")
    main-------   # 这一行打印出,说明主进程运行完。p1就立马死了,可能会有123打印
    456
    end456
    

      

     
  • 相关阅读:
    打开XX.etl文件
    ubuntu 安装 openssh-server,xinetd,vmware tools
    ESXi时间同步
    常用正则表达式字符说明
    RPC 服务器不可用
    linux 常用命令
    解决RDP连接不上
    python数据持久存储-pickle模块
    lambda表达式/对象引用计数
    关闭网络打开远程文件时防火墙安全弹窗
  • 原文地址:https://www.cnblogs.com/fantsaymwq/p/10127938.html
Copyright © 2011-2022 走看看