zoukankan      html  css  js  c++  java
  • python 并发编程 多进程 守护进程

    一 守护进程

    主进程创建子进程目的是:主进程有一个任务需要并发执行,那开启子进程帮我并发执行任务

    主进程创建子进程,然后将该进程设置成守护自己的进程

     

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

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

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

     

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

     

     子进程还没来得及开始就挂了

    设置了守护进程 就是不给子进程运行

    守护进程必须在开启子进程前开启

    from multiprocessing import Process
    import time
    
    def task(name):
    
    
        print("%s is running" % name)
        time.sleep(3)
        print("%s is done" % name)
    
    
    if __name__ == "__main__":
    
        t = Process(target=task, args=('子进程1',))
    
        # 守护进程必须在开启子进程前开启
        t.daemon = True
        t.start()
    
    
        print("")
    
    ''''''

    开一个子进程是为了并发任务, 这个子进程的任务,在主进程死了,这个任务就没有意义存在,这个子进程就应该设置守护进程

    守护进程练习题

    在主进程代码执行完毕,只要出现打印主进程信息,p1就不会执行或者死掉

    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-------
    456
    end456
    '''
  • 相关阅读:
    MongoDB 分片管理(一)检查集群状态
    MongoDB 副本集
    MongoDB 集群设置集合分片生效及查看集合分片情况
    mongodb 导入json文件遇到的坑
    GreenPlum/postgres copy命令导出/导入数据
    Mongo mongoexport/mongoimport介绍
    mongoDB之监控工具mongostat
    Oracle ORA-00600[2662] 解决
    ORA-00600[2662]问题 汇总
    MySQL的基本使用
  • 原文地址:https://www.cnblogs.com/mingerlcm/p/8991904.html
Copyright © 2011-2022 走看看