zoukankan      html  css  js  c++  java
  • python 多进程 无数进程 重复进程 死机

    import time  
    from multiprocessing import Process

    def processFunc(num,time1):
        print num
        time.sleep(time1)
        
    if __name__ == '__main__':  
        child_proc1 = Process(target=processFunc, args=(1,2)) 
        child_proc1.start()
        child_proc1.join()


    很简单的程序
    如果不写if __name__ == '__main__':    就会产生无数进程 最终占据所有内存
    原因:
    __name__是指示当前py文件调用方式的方法。如果它等于"__main__"就表示是直接执行,如果不是,则用来被别的文件调用,这个时候if就为False,那么它就不会执行最外层的代码了。
    这样的话,子进程一载入这个文件,就会调用 processFunc 函数,会执行生成子进程的代码,因为他是最外层代码,或者叫做全局代码,从而产生多个进程。
    一点小经验分析

  • 相关阅读:
    python3之datetime模块
    python3之time模块
    前端面试题01
    前端面试题02
    angularjs
    nodejs
    android 报错记录
    android知识点回顾二
    android知识点回顾
    Broadcast广播代码例子
  • 原文地址:https://www.cnblogs.com/zhihaowang/p/10128360.html
Copyright © 2011-2022 走看看