multiproccessing.Process subprocess.Popen os.popen 关系

相同点:

       都是启动了一个进程去执行任务。

       其中os.popen内部实现是调用了subprocess.Popen,只是对subprocess.Popen的简单封装

 

不同点:

       subprocess.Popen

              侧重和外部程序交互,执行一段命令,这个命令可以是启动一个程序,跑一个脚本,所以会有stdin stdout stderr这样的信息,是和当前进程的代码做不一样的东西。

              Popen是异步的,使用方式入下

proc = subprocess.Popen(argv)

        这样的代码执行完后, 另一个进程已经在跑了, 程序会直接继续执行接下来的代码的逻辑,主程序执行完退出后不影响Popen的进程。

         如果希望等结束后才继续执行(同步),可以用proc.wait()(也可以直接用subprocess.run)。

       multiprocessing.Process

             侧重当前进程中的一段代码逻辑 多开几个进程一起跑,加快处理速度,是本身的代码以及运行环境的复制。

             Process也是异步的,

p=multiprocessing.Process(target=f)

     这段代码执行完时,进程未开始执行,p.start() 开始执行。主程序执行完退出后该进程会强制退出。

       如果希望长驻后台,主程序退出不影响改进程,可以通过p.daemon=True进行设置。

       如果希望同步用p.join()等执行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值