自学Python 56 多线程开发(六)使用 Process

​Python 使用 Process

活动地址:CSDN21天学习挑战赛



  本文在多线程开发(五)使用进程库multiprocessing的基础上继学习multiprocessing模块中的内容。


一、使用 Process

  在Python的multiprocessing模块中,通过创建Process对象,然后调用其start() 方法来生成进程。在类Process中包含如下所示的内置成员:
  (1) multiprocessing.Process(group=Nore,target=None, name=None, args=(), kwargs={},* , daemo=None): 进程对象表示在单独进程中运行的活动。参数说明如下表所示。类Process具有类threading.Thread中的所有同名方法的功能。在Python 中,应始终使用关键字参数调用这个构造函数。

参数名称描述
group应始终为None, 仅仅与treding.Thread 兼容
target是由run()方法调用的可调用对象,默认值为None, 表示不调用任何内容
name是进程名称
args是目标调用的参数元组
kwargs是目标调用的关键学参数的字典,如果提供此参数值,则将关键进程daemon标记设置为True或False
daemon如果将daemon标记设置为None (默认值),则此标志将从创建过程继承

  如果一个子类覆盖了构造方法,则必须确保在对进程做任何其他事情之前调用基类构造方法(Process. init ())。
  (2) daemon: 进程的守护标志,是一个布尔值,必须在调用start() 之前设置。
  (3) pid: 返回进程ID,在生成进程之前是None。
  (4) exitcode: 子进程的退出代码。如果进程尚未终止则是None,负值-N则表示子进程被信号N终止。
  (5) authkey: 进程的认证密钥(字节字符串)。当初始化multiprocessing时,使用os.urandom()为主进程分配一个随机字符串;当创建Process对象时,将继承其父进程的认证密钥,但以通过将authkey设置为另一个字节字符串来更改。
  (6) sentinel: 系统对象的数字句柄,在进程结束时将变为“就绪”。当使用multiprocessing.connection.wait()一次等待多个事件建议使用此值,否则调用join()将更简单。在Windows系统中,这时可与WaitForSingleObject和WaitForMultipleObjects API调用系列一起使用的操作系统句柄。在Unix系统中,这是一-个文件描述器,可以使用来自select模块的原语。
  (7) terminate(): 终止进程。在Unix系统中,是使用SIGTERM信号完成的;在Windows系统中使用TerminateProcess()。注意,退出处理程序和finally子句等不会被执行。
  例如下面的实例演示了使用Process对象生成进程的过程。

import os
import threading
import multiprocessing

def worker(sign, lock):
    lock.acquire()
    print(sign,os.getpid())
    lock.release()
print('Main:',os.getpid())
record = []
lock = threading.Lock()
for i in range(5):
    thread = threading.Thread(target=worker,args=('thread',lock))
    thread.start()
    record.append(thread)
for thread in record:
    thread.join()
record = []
lock = multiprocessing.Lock()
for i in range(5):
    process = multiprocessing.Process(target=worker,args=('process',lock))
    process.start()
    record.append(process)
for process in record:
    process.join()

  通过上述代码可以看出,Thread 对象和Proces对象在使用上的相似性与结果上的不同。各个线程和进程都做一件事: 打印PID。但问题是所有的任务在打印的时候都会向同一个标准输出(stdout) 。这样输出的字符会混合在一起,无法阅读。使用Lock同步,在一个任务输出完成之后,再允许另个任务输出, 可以避免多个任务同时向终端输出。所有Thread的PID都与主程序相同,而每个Process都有一个不同的PID。执行后会输出:
在这里插入图片描述

…省略部分执行效果

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python的PyQt5,处理多线程主要有三种方法。第一种是使用计时器模块QTimer,第二种是使用多线程模块QThread,第三种是使用事件处理功能。 在第二种方法,需要编写一个线程类文件,并在其定义一个自定义信号。然后在run()函数编写希望在线程执行的操作。例如,可以使用time.sleep()函数实现计时操作,并通过emit函数将参数传递给主线程,从而触发自定义信号。 在第三种方法,需要导入前面两个文件,并定义一个包含相关逻辑操作的类。可以通过实例化一个线程,并设置参数,然后将线程的信号与UI主线程的槽函数进行连接。最后,启动线程并接收通过emit传来的信息,执行相应的操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [PYQT5实现多线程的方法](https://blog.csdn.net/GDUT_ZXM/article/details/121353212)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [PyQt5自学记录(1)——PyQt5多线程实现详解](https://blog.csdn.net/qq_40784418/article/details/105398870)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值