关键词搜索

源码搜索 ×
×

Python 中进程和线程的用法基本一样

发布2021-09-27浏览304次

详情内容

辅助视频教程:Python基础教程|xin3721自学网ul li id=itemtitlePython3 从入门到精通视频教程/li /ul ul li class=description Python是一种跨平台的计算机程序设计语言。是一种面向对象的动态类型语言,最初被设计用于编写自动化脚本(shell),icon-default.png?t=L892https://www.xin3721.com/eschool/pythonxin3721/

一、进程的创建

我们先来回忆下之前多线程的实现。

  1. import threading
  2. import time
  3. def test1():
  4. while True:
  5. print("1------")
  6. time.sleep(1)
  7. def test2():
  8. while True:
  9. print("https://cdn.jxasp.com:9143/image/2------")
  10. time.sleep(1)
  11. def main():
  12. t1 = threading.Thread(target=test1)
  13. t2 = threading.Thread(target=test2)
  14. t1.start()
  15. t2.start()
  16. if __name__ == "__main__":
  17. main()

再来看看多进程的实现。

  1. import multiprocessing
  2. import time
  3. def test1():
  4. while True:
  5. print("1------")
  6. time.sleep(1)
  7. def test2():
  8. while True:
  9. print("https://cdn.jxasp.com:9143/image/2------")
  10. time.sleep(1)
  11. def main():
  12. t1 = multiprocessing.Process(target=test1)
  13. t2 = multiprocessing.Process(target=test2)
  14. t1.start()
  15. t2.start()
  16. if __name__ == "__main__":
  17. main()

multiprocessing 模块就是跨平台版本的多进程模块,提供了一个 Process 类来代表一个进程对象,这个对象可以理解为是一个独立的进程,可以执行另外的事情。

创建子进程时,只需要传入一个执行函数和函数的参数,创建一个 Process 实例,用start()方法启动。

通过比较,会惊奇地发现,创建多线程和创建多进程,步骤几乎是一样的。

和使用 Thread 类创建多线程方法类似,使用 Process 类创建多进程也有以下 2 种方式:

  1. 直接创建 Process 类的实例对象,由此就可以创建一个新的进程;
  2. 通过继承 Process 类的子类,创建实例对象,也可以创建新的进程。注意,继承 Process 类的子类需重写父类的 run() 方法。

二、Process 语法结构

Process([group [, target [, name [, args [, kwargs]]]]])
  • target:如果传递了函数的引用,可以认为这个子进程就执行这里的代码。
  • args:给 target 指定的函数传递非关键字参数,以元组的方式传递。
  • kwargs:给 target 指定的函数传递命名(关键字)参数。
  • name:给进程设定一个名字,可以不设定。
  • group:指定进程组,大多数情况下用不到。

Process 创建的实例对象的常用方法

  • start():启动子进程实例(创建子进程)。
  • is_alive():判断进程子进程是否还在活着。
  • join([timeout]):是否等待子进程执行结束,或等待多少秒。
  • terminate():不管任务是否完成,立即终止子进程。
  • run():继承类中需要对该方法进行重写,该方法中包含的是新进程要执行的代码。

Process创建的实例对象的常用属性

  • name:当前进程的别名,默认为Process-N,N为从1开始递增的整数。
  • pid:当前进程的pid(进程号)。
  • daemon:和守护线程类似,通过设置该属性为 True,可将新建进程设置为守护进程。

三、获取进程的pid

  1. from multiprocessing import Process
  2. import os
  3. def run_proc():
  4. """子进程要执行的代码"""
  5. # os.getpid获取当前进程的进程号
  6. print('子进程运行中,pid=%d...' % os.getpid())
  7. print('子进程将要结束...')
  8. if __name__ == '__main__':
  9. # os.getpid获取当前进程的进程号
  10. print('父进程pid: %d' % os.getpid())
  11. p = Process(target=run_proc)
  12. p.start()

运行结果:

  1. 父进程pid: 12740
  2. 子进程运行中,pid=11192...
  3. 子进程将要结束...

四、给子进程指定的函数传递参数

  1. from multiprocessing import Process
  2. import os
  3. from time import sleep
  4. def run_proc(name, age, **kwargs):
  5. for i in range(10):
  6. print('子进程运行中,name= %s,age=%d ,pid=%d...' % (name, age, os.getpid()))
  7. print(kwargs)
  8. sleep(0.2)
  9. if __name__ == '__main__':
  10. p = Process(target=run_proc, args=('test', 18), kwargs={"m": 20})
  11. p.start()
  12. # 1秒中之后,立即结束子进程
  13. sleep(1)
  14. p.terminate()
  15. p.join()

运行结果:

  1. 子进程运行中,name= test,age=18 ,pid=10024...
  2. {'m': 20}
  3. 子进程运行中,name= test,age=18 ,pid=10024...
  4. {'m': 20}
  5. 子进程运行中,name= test,age=18 ,pid=10024...
  6. {'m': 20}
  7. 子进程运行中,name= test,age=18 ,pid=10024...
  8. {'m': 20}
  9. 子进程运行中,name= test,age=18 ,pid=10024...
  10. {'m': 20}

编程的朝圣之路

 

相关技术文章

点击QQ咨询
开通会员
返回顶部
×
微信扫码支付
微信扫码支付
确定支付下载
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载