• day29-1 守护进程


    守护进程

    守护进程会在主进程代码执行结束后和主进程一起终止

    # 守护进程
    import time
    from multiprocessing import Process
    
    
    def task1():
        print('son1 process run:', time.ctime())
        time.sleep(3)
        print('son1 process stop:', time.ctime())
    
    
    def task2():
        print('son2 process run:', time.ctime())
        time.sleep(5)
        print('son2 process stop:', time.ctime())
    
    
    if __name__ == '__main__':
        p1 = Process(target=task1)
        p2 = Process(target=task2)
    
        p1.daemon = True  # 将p1子进程设为主进程的守护进程,必须要写在开启该子进程的前面
        p1.start()  # 开启进程p1
        p2.start()  # 开启进程p2
    
        time.sleep(1)
        print('parent process stop:', time.ctime())
    -----------------------------------------------------------------
    son2 process run: Wed Jul  3 15:34:43 2019  
    son1 process run: Wed Jul  3 15:34:43 2019
    parent process stop: Wed Jul  3 15:34:44 2019  # 在子进程结束时,p1子进程跟着结束,所以son1 process stop不打印
    son2 process stop: Wed Jul  3 15:34:48 2019
    

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

    # 在守护进程内开启子进程,抛出异常:AssertionError: daemonic processes are not allowed to have children
    import time
    from multiprocessing import Process
    
    
    def task11():
        print('son son process:', time.ctime())
    
     
    def task1():
        p11 = Process(target=task11)
        p11.start()
    
    
    if __name__ == '__main__':
        p1 = Process(target=task1)
    
        p1.daemon = True
        p1.start()
    
        time.sleep(1)
        print('parent process stop:', time.ctime())
    -----------------------------------------------------------------------------
    Process Process-1:
    Traceback (most recent call last):
      File "C:Python3libmultiprocessingprocess.py", line 258, in _bootstrap
        self.run()
      File "C:Python3libmultiprocessingprocess.py", line 93, in run
        self._target(*self._args, **self._kwargs)
      File "E:python9day32	est.py", line 16, in task1
        p11.start()
      File "C:Python3libmultiprocessingprocess.py", line 103, in start
        'daemonic processes are not allowed to have children'
    AssertionError: daemonic processes are not allowed to have children
    parent process stop: Wed Jul  3 15:42:33 2019
    
    
    # 不设守护进程,在子进程内开启子进程.类似于一种嵌套
    import time
    from multiprocessing import Process
    
    
    def task11():
        print('son1 son process:', time.ctime())
    
    
    def task1():
        p11 = Process(target=task11)
        p11.start()
        time.sleep(1)
        print('son process:',time.ctime())
    
    
    if __name__ == '__main__':
        p1 = Process(target=task1)
        p1.start()
        time.sleep(1)
        print('parent process stop:', time.ctime())
    -----------------------------------------------------------------------------
    son1 son process: Wed Jul  3 15:48:34 2019
    parent process stop: Wed Jul  3 15:48:34 2019
    son process: Wed Jul  3 15:48:35 2019
    
  • 相关阅读:
    JavaScript Patterns and Good Parts
    [Buzz Today]2012.05.015
    The first glance at Python
    The first glance at JavaScript
    [Buzz Today]2012.05.06
    vs.net2008 下 带完善后台管理的flash+js 轮显广告
    Vs.net2008 下 Ajaxpro 使用
    允许asp上传大文件的设置
    使用AutocompleteExtender无效或者没反应,输入啥都在webservice里面跟踪不到
    C#精髓 GridView 72般绝技
  • 原文地址:https://www.cnblogs.com/863652104kai/p/11126964.html
Copyright © 2020-2023  润新知