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
'''

 

posted @ 2019-06-17 18:57  minger_lcm  阅读(1803)  评论(0编辑  收藏  举报