python 多任务之多进程

多任务

优势

多个任务同时执行可以大大提高程序执行效率,可以充分利用CPU资源,提高程序的执行效率

概念

是指在同一时间内执行多个任务

多进程

概念

进程(process)是资源分配的最小单位,他是操作系统进行资源分配和调度运行的基本单位,比如:一个正在运行的程序就是一个进程,如QQ,微信等

一个程序的运行至少有一个进程,在程序运行后,默认会创建一个进程,称之为主进程,在主进程里面创建的进程,称之为子进程

进程的创建步骤

1.导入进程所需要的包
import multiprocessing


2.通过进程类创建进程对象
进程对象 = multiprocessing.Process(target=任务名)


3.启动进程
进程对象.start()

多进程的使用

import multiprocessing
import time

def eat():
    for i in range(10):
        print('正字吃饭=============')
        time.sleep(0.5)        # 等待0.5秒后再执行


def music():
    for i in range(10):
        print('正在唱歌=============')
        time.sleep(0.5)       # 等待0.5秒后再执行


if __name__ == '__main__':
    eat_process = multiprocessing.Process(target=eat,)
    music_process = multiprocessing.Process(target=music,)

    eat_process.start()
    music_process.start()

运行结果

进程执行任务函数的传参

  • 元组方式传参:元组方式传参一定要和参数的顺序保持一致
  • 字典方式传参:字典方式传参字典中的key一定要和参数名保持一致
import time
import multiprocessing

def eat(num, name):
    for i in range(num):
        print(f'{name}正字吃饭=============')
        time.sleep(0.5)  # 每隔0.5秒执行一次

def music(num, name):
    for i in range(num):
        print(f'{name}正在唱歌=============')
        time.sleep(0.5)  # 每隔0.5秒执行一次

if __name__ == '__main__':
    # 放在元组里面和传进去的参数一一对应,后面一定得加逗号
    eat_process = multiprocessing.Process(target=eat, args=(5, '张三'))
    # 放在字典里面是键值对形式,必须和传进入的参数名字一样,变量名一样
    music_process = multiprocessing.Process(target=music, kwargs={'num': 5, 'name': '张三'})

    eat_process.start()
    music_process.start()

执行结果

获取进程编号和杀死进程

作用:当程序中的进程数量很多,编号就是用来区分主进程和不同的子进程,进行有效的进程管理

获取进程编程的两种方式

1.获取当前进程编号,os.getpid()
import os
print('当前进程编号是:', os.getpid())


2.获取当前父进程编号,os.getppid()

import os
print('当前进程的父进程编号是:', os.getppid())

执行结果 

杀死进程kill

根据进程编号杀死指定进程

os.kill(进程编号, 9)

import os
import multiprocessing
import time

def work():
    # 查看当前进程
    current_process = multiprocessing.current_process()
    # 获取当前进程的编号
    print('work进程编号:', current_process.pid, os.getpid())
    # 获取父进程的编号
    print('work父进程的编号:', os.getppid())
    for i in range(20):
        print('正在工作=============')
        time.sleep(0.5)
        # 根据进程编号杀死对应的进程
        os.kill(os.getpid(), 9)

work()

执行结果

当第16行代码是这个的话   os.kill(os.getppid(), 9)    会怎么样呢?

程序会在执行一次print后,直接退出整个pycharm

管理不同的进程
import multiprocessing
import os

def eat():
    print('这是吃饭的进程的编号===', os.getpid())
    print('这是吃饭的父进程的编号===', os.getppid())

def music():
    print('这是唱歌的进程的编号===', os.getpid())
    print('这是唱歌的父进程的编号===', os.getppid())

if __name__ == '__main__':
    # 获取主进程的编号
    print('这是主进程的编号====', os.getpid())
    print(end='\n')

    eat_process = multiprocessing.Process(target=eat,)
    music_process = multiprocessing.Process(target=music,)

    eat_process.start()
    music_process.start()

执行结果

进程之间不共享全局变量

import time
import multiprocessing

def write_date():
    for i in range(3):
        my_list.append(i)
    print('这是子进程写入的表:', my_list)

def read_date():
    print('这是子进程读数据', my_list)


my_list = []

if __name__ == '__main__':

    write_process = multiprocessing.Process(target=write_date)
    read_process = multiprocessing.Process(target=read_date)

    write_process.start()
    # 主进程等待写入进程执行完成以后代码,再继续往下执行
    time.sleep(1)
    read_process.start()     # 这里是读不出来的,因为进程之间不共享全局变量

    print('这是主进程的:', my_list)     # 这里也是输出不了,只是三个变量名一样,但不是操作同一个全局变量

执行结果

守护主进程和销毁子进程

主进程会等待所有的子进程执行结束再结束

为了保证子进程能够正常运行,主进程会等待所有的子进程执行完成以后再销毁,设置守护主进程的目的是主进程退出子进程销毁,不让主进程再等待子进程去执行

两种方式都能保证主进程退出子进程销毁

        1、设置守护主进程:子进程对象.daemon = True
        2、销毁子进程:子进程对象.terminate()

import multiprocessing
import time

def eat():
    for i in range(10):
        print('正在吃饭==============')
        time.sleep(0.5)

if __name__ == '__main__':
    # 创建子进程
    eat_process = multiprocessing.Process(target=eat,)
    # 启动子进程
    eat_process.start()
    time.sleep(1)
    print('主进程执行完毕==========')

执行结果 

设置守护主进程
import multiprocessing
import time

def eat():
    for i in range(10):
        print('正在吃饭==========')
        time.sleep(0.5)

if __name__ == '__main__':

    eat_process = multiprocessing.Process(target=eat,)
    # 设置守护主进程,主进程退出后子进程直接销毁,不再执行子进程中的代码
    # 设置守护主进程必须在启动子进程之前
    eat_process.daemon = True
    eat_process.start()

    # 让主进程等待一秒
    time.sleep(2)
    print('主进程执行完毕========')

执行结果

销毁子进程
import multiprocessing
import time

def eat():
    for i in range(10):
        print('正在吃饭==========')
        time.sleep(0.5)

if __name__ == '__main__':

    eat_process = multiprocessing.Process(target=eat,)
    eat_process.start()

    # 让主进程等待一秒
    time.sleep(2)
    # 手动结束子进程,这个方式要写在开启子进程的下面
    eat_process.terminate()

    print('主进程执行完毕========')

执行结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/691238.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue3【十二】09Computed计算属性

Vue3【十二】09Computed计算属性 计算属性 获取全名 这种方式是只读的不能修改 这样定义fullName是一个计算属性&#xff0c;可读可写 案例截图 目录结构 代码 Person.vue <template><div class"person"><h1>我是 Person 组件</h1>姓&…

Latex中表格(3)

Latex中的表格 一、多行或多列单元格 这篇主要说Latex中表格出现多行或者多列单元格的形式. 一、多行或多列单元格 可能用到的宏包 \usepackage{booktabs}\usepackage{multirow} 代码&#xff1a; \begin{table}[h!] \centering \caption{Your caption here} \begin{tabul…

Vue学习day05笔记

day05 一、学习目标 1.自定义指令 基本语法&#xff08;全局、局部注册&#xff09;指令的值v-loading的指令封装 2.插槽 默认插槽具名插槽作用域插槽 3.综合案例&#xff1a;商品列表 MyTag组件封装MyTable组件封装 4.路由入门 单页应用程序路由VueRouter的基本使用 …

张量之力:人工智能的多维舞台

在人工智能&#xff08;AI&#xff09;的广阔天地里&#xff0c;张量&#xff08;Tensor&#xff09;这一数学概念如同璀璨的明星&#xff0c;以其独特的魅力和强大的功能&#xff0c;为AI技术的发展和应用注入了新的活力。张量&#xff0c;这个源自物理学的概念&#xff0c;如…

day32--Spring(一)

一、Spring简介 1 Spring课程介绍 问题导入 我们为什么要学习Spring框架&#xff1f; 1.1 为什么要学 Spring技术是JavaEE开发必备技能&#xff0c;企业开发技术选型命中率>90% 专业角度 简化开发&#xff0c;降低企业级开发的复杂性框架整合&#xff0c;高效整合其他技…

浅谈安全用电管理系统对重要用户的安全管理

1用电安全管理的重要性   随着社会经济的不断发展&#xff0c;电网建设力度的不断加大&#xff0c;供电的可靠性和供电质量日益提高&#xff0c;电网结构也在不断完善。但在电网具备供电的条件下&#xff0c;部分高危和重要电力用户未按规定实现双回路电源线路供电&#xff1…

nomachine使用记录以及录包以及自动画深度学习网络图

录包命令&#xff1a; rosbag record 话题名字&#xff08;可以是原相机话题和执行程序的话题&#xff09;rosbag play 包名&#xff08;可以离线播放包的数据&#xff09; rqt_image_view 话题可视化yolov8自动生成网络结构图&#xff1a; pip install tensorflowtensorboard…

高考后的职业规划:学习LabVIEW开发前景广阔

在今天的高考后&#xff0c;选择学习LabVIEW开发为未来职业规划将大有可为。LabVIEW以其图形化编程、强大的数据处理和硬件集成功能&#xff0c;广泛应用于工程、科研、自动化测试等领域。掌握LabVIEW开发技能&#xff0c;不仅就业前景广阔&#xff0c;还能参与前沿技术应用&am…

【web前端开发】标签(基础知识详解)

浏览器能识别的标签 编码 <meta charset"UTF-8"> title <title>helloshh</title> 标题 <h1>1级标签</h1> <h2>2级标签</h2> <h3>3级标签</h3> <h4>4级标签</h4> <h5>5级标签</h5> &…

Redis 实现持久化

Redis ⽀持 RDB ( 定期备份 ) 和 AOF ( 实时备份 ) 和 混合持久化 (结合RDB 和 AOF 的特点) 持久化机制&#xff0c;持久化功能有效地避免因进程退出造成数据丢失问题&#xff0c; 当下次重启时利⽤之前持久化的⽂件即可实现数据恢复。 RDB&#xff08;Redis DataBase&#xff…

网络编程之XDP技术介绍

一、简介 XDP&#xff1a;eXpress Data Path&#xff0c;快速数据面&#xff0c;听名字是不是很高大上。其实它就是一个快速处理Rx数据包的数据面技术。为什么现在对数据处理如此敏感&#xff1f;原因非常简单&#xff0c;随着网络的不断覆盖社会的各个层面&#xff0c;海量的…

手撕C语言题典——相交链表

目录 前言 一&#xff0c;思路 1&#xff09;暴力 2)同步指针 二&#xff0c;代码实现 前言 依旧是力扣上的一道题&#xff0c;有许多新思路提供给我们 160. 相交链表 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/intersection-of-two-linked-li…

烧写uboot、linux镜像、根文件系统到开发板

烧写uboot、linux镜像、根文件系统到开发板 环境介绍 本博客使用x6818开发板。 公司&#xff1a;三星 ARM架构 Cortex-A53核 型号&#xff1a;S5P6818 特性&#xff1a;8核&#xff0c;最高主频2GHz 烧写uboot 使用网络烧写 网络烧写上位机是Ubuntu虚拟机。 先利用上…

运 算 符

算术运算符 算术运算符包括&#xff1a;&#xff0c;-&#xff0c;*&#xff0c;/&#xff0c;%&#xff0c;&#xff0c;-- 当左右两边都是数值型时&#xff0c;则做加法运算。 当左右两边有一方为字符串&#xff0c;则做拼接运算。任何一个 Java 对象都可以转换为字符串。 …

【Python】 闭包

什么是闭包 用一句话粗略概况为&#xff1a;在一个函数内&#xff0c;读取外部函数定义的变量的机制。更一般地说&#xff0c;闭包函数是带有状态的函数&#xff0c;状态是指调用环境的上下文&#xff0c;当函数带上了状态就是闭包。 如下代码&#xff0c;在函数f内定义了一个…

pyinstall 打包 paddleocr 成为.exe文件步骤

一、首先进入虚拟环境 使用pip安装pyinstaller pip install pyinstaller我的已经安装完成 二、用cmd进入当前打包文件夹下&#xff0c;新建使spec文件内容如下 注意&#xff1a;其中需要修改的部分是pathex中文件所在路径文件内容摘抄自另一篇博文(❄点击可查看❄) # -*- m…

pytorch 加权CE_loss实现(语义分割中的类不平衡使用)

加权CE_loss和BCE_loss稍有不同 1.标签为long类型&#xff0c;BCE标签为float类型 2.当reduction为mean时计算每个像素点的损失的平均&#xff0c;BCE除以像素数得到平均值&#xff0c;CE除以像素对应的权重之和得到平均值。 参数配置torch.nn.CrossEntropyLoss(weightNone,…

2024 cicsn ezbuf

文章目录 参考protobuf逆向学习复原结构思路exp 参考 https://www.y4ng.cn/posts/pwn/protobuf/#ciscn-2024-ezbuf protobuf 当时压根不知道用了protobuf这个玩意&#xff0c;提取工具也没提取出来&#xff0c;还是做题做太少了&#xff0c;很多关键性的结构都没看出来是pro…

Vue的基础知识:v-model的原理,由:value与@input合写。

原理&#xff1a;v-model本质上是一个语法糖&#xff0c;比如应用在输入框上&#xff0c;就是value属性和input事件的合写。&#xff08;补充说明&#xff1a;语法糖就是语法的简写&#xff09; 作用&#xff1a;提供数据的双向绑定 1.数据变&#xff0c;视图&#xff08;也就…

spring-kafka-生产者服务搭建测试(SpringBoot整合Kafka)

文章目录 1、生产者服务搭建1.1、引入spring-kafka依赖1.2、application.yml配置----v1版1.3、使用Java代码创建主题分区副本1.4、发送消息 1、生产者服务搭建 1.1、引入spring-kafka依赖 <?xml version"1.0" encoding"UTF-8"?> <project xml…