Day06 Python 中的进程(创建进程、队列、进程池)

在这里插入图片描述

一、进程是什么?

1、定义

一个程序运行起来后,代码+用到的资源 称之为进程,它是操作系统分配资源的基本单元。

Pass:进程是资源分配的最小单位,线程是cpu调度的最小单位

2、进程中的状态

工作中,任务数往往大于CPU核数,也就是说有部分任务正在执行,也有另一部分任务正在等待CPU进行执行,也就出现了不同的状态。
五种进程状态:新建、就绪、堵塞、运行、死亡
在这里插入图片描述

  • 就绪态:运行的条件都已经满足,等待CPU执行
  • 执行态:正在执行的进程
  • 等待态:满足运行条件之后,等待CPU执行

二、创建进程

1、常用的属性 name pid

import os  # 多种操作系统接口模块
from multiprocessing import Process   #在multiprocessing模块中导入process类
def f1():
    print(f'f1子进程的id是{
     os.getpid()},父进程id为{
     os.getppid()}')
def f2():
    print(f'f2子进程的id是{
     os.getpid()},父进程id为{
     os.getppid()}')
if __name__ == '__main__':
    # 创建子进程
    p1 = Process(target=f1)
    p2 = Process(target=f2)
    # 启动进程
    p1.start()
    p2.start()
    # 修改进程名
    p1.name = 'our'
    print('p1的子进程名是',p1.name)
    print(f'主进程的id是{
     os.getpid()},父进程id为{
     os.getppid()}')
    
# 结果:
# p1的子进程名是 our
# 主进程的id是18532,父进程id为7904
# f1子进程的id是1632,父进程id为18532
# f2子进程的id是26292,父进程id为18532

2、常用的方法 is_alive()和join()

start()启动
is_alive()判断进程子进程是否还活着,如果存活则返回True,否则为False;
join() 阻塞
terminate()不管任务是否完成,立即终止进程
例子1

from multiprocessing import Process
def study(name):
    print(f'{
     name}学习很认真')
def smile(name)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python,多进程编程时要实现进程间的共享变量,可以使用multiprocessing模块的Value和Array来实现。Value用于共享一个单一的值,而Array用于共享一个数组。这两个类都是通过共享内存来实现进程间的数据共享。 下面是一个示例代码,展示了如何在多进程共享变量: ```python from multiprocessing import Process, Value def worker1(x): x.value += 1 print(f"x in worker1: {x.value}") def worker2(x): x.value += 1 print(f"x in worker2: {x.value}") if __name__ == '__main__': x = Value('i', 0) # 创建一个共享整数变量 p1 = Process(target=worker1, args=(x,)) p2 = Process(target=worker2, args=(x,)) p1.start() p2.start() p1.join() p2.join() print(f"x in main: {x.value}") ``` 在这个示例,我们使用Value('i', 0)创建了一个共享整数变量x。在worker1和worker2函数,我们通过x.value来访问和修改共享变量x的值。最后,在主进程打印出了共享变量x的值。 通过使用Value和Array,我们可以在多进程编程实现共享变量的目标。这样,不同的进程就可以访问和修改同一个变量,实现了数据的共享。 #### 引用[.reference_title] - *1* *2* [Python进程共享全局变量:实现多进程全局变量](https://blog.csdn.net/update7/article/details/129808004)[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^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [python3 多进程共享变量实现方法](https://blog.csdn.net/whatday/article/details/103472673)[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^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值