Python基础学习 -- 进程锁

news2025/1/12 16:01:15

一、join函数的作用

1、等子进程执行完,主进程再结束

2、将子进程都存储到一个列表,每个子进程都调用一下join方法

if __name__=="__main__":
    print("我是主线程")
    s=time.time()
    a=[2,3,4]
    b=[] #存储创建好的进程
    for i in a:
        p=Process(target=funa,args=(i,))
        p.start()
    print("程序花费:",time.time()-s)

两个进程间的数据,是不能共享的

二、面向对象启动子进程

1、新建一个类aiyou,传递的参数为Process

2、新建一个run方法,名字必须是run,子进程默认执行的函数

from multiprocessing import Process

class aiyou(Process):
    def __init__(self, name):
        super().__init__()
        self.name = name

    def run(self):
        print('当前%s子进程正在执行'%self.name)

if __name__ == '__main__':
    p = aiyou('bucuo')
    p.start()

三、守护进程

1、当没有守护进程的时候,主进程结束后,子进程依旧执行完毕才结束

import time
from multiprocessing import Process
def funa(n):
    for i in range(n):
        time.sleep(1)
        print("我是a")


if __name__=="__main__":
    print("我是主线程")
    s=time.time()
    a=[2,3,4]
    for i in a:
        p=Process(target=funa,args=(i,))
        p.start()
    print("程序花费:",time.time()-s)

2、将子进程设置成守护进程(p.daemon=True),主进程一结束,子进程立马结束

import time
from multiprocessing import Process
def funa(n):
    for i in range(n):
        time.sleep(1)
        print("我是a")

if __name__=="__main__":
    print("我是主线程")
    s=time.time()
    a=[2,3,4]
    for i in a:
        p=Process(target=funa,args=(i,))
        p.daemon=True
        p.start()
    print("程序花费:",time.time()-s)

四、进程同步(锁)

1、当创建多个子进程的时候,他们的启动顺序是不一样

import time
from multiprocessing import Process
from multiprocessing import Lock

def funa():
    for i in range(10000):
        print("我是%d开始执行"%i)

def funb(l):
    #l.acquire()
    funa()
    #l.release()

if __name__=="__main__":
    print("我是主线程")
    lock=Lock()
    for i in range(3):
        p=Process(target=funb,args=(lock,))
        p.start()

运行结果(部分截图),这里执行的顺序就变了

2、枷锁以后,就会按顺序挨个执行

加锁的缺点,使进程失去了异步的功能,优点是:数据更加安全

import time
from multiprocessing import Process
from multiprocessing import Lock

def funa():
    for i in range(10000):
        print("我是%d开始执行"%i)

def funb(l):
    l.acquire()
    funa()
    l.release()

if __name__=="__main__":
    print("我是主线程")
    lock=Lock()
    for i in range(3):
        p=Process(target=funb,args=(lock,))
        p.start()

运行结果:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

入门算法,这篇文章你得看!(java、算法基础、常用算法)

想用Java快速入门算法?这篇文章你得看! 提示:本文章适合想要入门算法,并且想 “快速” 达到一定成果的同学们阅读~ 文章非常非常非常长(可能是你见过最长的博客)!!! 阅读…

Authing 身份云入选《数字身份治理与管理(IGA)应用实践指南》报告

身份是物理实体映射在网络空间的一串数字代码,是数字世界的通行证。掌控了统一的权威数字身份就等同掌控了实体在数字空间的行为。网络业务的快速发展,使业务与安全深度融合到一起,并使数字身份成为数字化经济建设的重要基石。同一实体可以更…

【数据结构初阶】第一篇——算法性能分析

算法效率 什么是大O 时间复杂度分析 概念 大O渐进表示法 不同数据规模的差异 复杂表达式的化简 O(logn)中的log是以什么为底? 案例分析 算法为什么会超时 递归算法的时间复杂度 空间复杂度分析 概念 案例分析 递归算法的性能分析 代码的内存消耗 算法效率 算法…

如何使用VMware虚拟机(带你快速了解)

前言 📜 “作者 久绊A” 专注记录自己所整理的Java、web、sql等,IT技术干货、学习经验、面试资料、刷题记录,以及遇到的问题和解决方案,记录自己成长的点滴 目录 前言 一、什么是虚拟机 二、VMware的简介 1、大概介绍 2、详…

数据结构 第四章 串

她:点击收听 1 基本知识点 1、串中的元素是字符 2、操作的对象往往不再是单个数据元素,而是一组数据元素(子串) 3、串:由零个或多个字符组成的有限序列 4、子串:串中任意连续个字符组成的子序列 5、包含子串的串又被称为该子串的主串 6、真…

LeetCode[685]冗余连接II

难度:困难题目:在本问题中,有根树指满足以下条件的 有向 图。该树只有一个根节点,所有其他节点都是该根节点的后继。该树除了根节点之外的每一个节点都有且只有一个父节点,而根节点没有父节点。输入一个有向图&#xf…

Linux 笔记3

5.Linux 的网络信息5.1主机名称5.1.1临时修改:hostname 新名字 (需要重新进入才能显示新名字)reboot重启虚拟机5.1.2永久:vi /etc/hostname5.2DNS解析dns解析域名域名-》ipdns域名劫持:将域名对应的ip改掉5.2.1修改主机…

networkx学习(四)无标度网络

networkx学习(四)无标度网络 无标度网络: 对于随机网络和规则网络,度分布区间非常狭窄,大多数节点都集中在节点度均值< k >的附近,说明节点具有同质性,因此< k >可以被看作是节点度的一个特征标度。而在节点度服从幂律分布的网络中,大多数节点的度都很小,…

从零创建vue示例

从零创建vue搭建node环境创建vue项目vue项目目录介绍搭建node环境 1.下载node(node官网) 安装node一路点next即可 2.windowR—cmd ----测试一下npm -v 以及node -v 显示版本号 3.执行以下命令&#xff08;-g表示全局安装&#xff09; npm install -g vue npm install -g vue…

优化命令 nload详解

优化命令 nload详解 引言 nload用于实时监控linux下网络流量信息&#xff0c;是命令行工具&#xff0c;用来监控网络的吞吐量。它使用两个图表数据来对进出站流量进行可视化。 一、nload安装 nload工具并不是centos自带的&#xff0c;需要我们手动安装下载 直接yum安装查不到…

Kettle 快捷引入数据库

在编写kettle任务时往往需要连接数据库&#xff0c;kettle一共提供了四种数据库配置方式&#xff0c;JDBC、ODBC、OCI、JNDI&#xff0c;我最初直接使用的最为熟悉的JDBC&#xff0c;但是多写几个转换程序就会发现&#xff0c;每新建一个转换任务文件时都需要重新配置数据信息&…

DDOS渗透与攻防(四)之应用层DoS攻击

系列文章 DDOS渗透与攻防(一)之拒绝服务攻击概念介绍 DDOS渗透与攻防(二)之SYN-Flood攻击 DDOS渗透与攻防(三)之socktress攻击 应用层DoS攻击 攻击协议原理介绍说明-应用层DoS 应用服务漏洞 服务代码存在漏洞&#xff0c;遇异常提交数据时程序崩溃应用处理大量并发请求能力…

Git(见Docx)

Git的概念【1】Git技术&#xff1a;公司必备&#xff0c;一定要会 【2】Git概念&#xff1a; Git是一个免费的、开源的分布式版本控制系统&#xff0c;可以快速高效地处理从小型到大型的项目。【3】什么是版本控制&#xff1f; 版本控制是一种记录一个或若干文件内容变化&#…

Redis 发布订阅模式的深度解析与实现消息队列

1 发布订阅模式(Pub/Sub)的概述我们可以利用Redis的List数据结构实现一个简单的消息队列&#xff0c;通过lpush命令写入消息&#xff0c;通过rpop 命令拉取消息&#xff0c;也可以使用BRPOP实现阻塞式的拉取消息。上面的消息队列有一个缺点&#xff0c;那就是不支持消息多播机制…

百趣代谢组学文献分享:以猪为模型检测哺乳动物之间的代谢物交换

百趣代谢组学文献分享&#xff0c;您对哺乳动物不同器官之间的代谢物交换情况了解吗&#xff1f; 本期百趣代谢组学小趣给大家分享的是美国普林斯顿大学Joshua D. Rabinowitz团队发表在Cell Metabolism上的研究成果。该团队以猪为模型&#xff0c;利用高通量靶标技术定量测定了…

QEMU/KVM带与不带音频驱动参数的实际区别

实际工作中用到QEMU/KVM&#xff0c;按照书中的命令启动虚拟机后&#xff0c;发现Ubuntu镜像启动后找不到声卡设备&#xff0c;经过一番搜索和尝试&#xff0c;最终发现是“-device ac97”这一关键选项所导致的。现将具体的对比结果记录如下&#xff1a; 不带“-device ac97”…

2023编程语言趋势

2023编程语言趋势 作为CTO&#xff0c;我需要持续关注编程语言的发展。按照惯例&#xff0c;每年年初我都会对未来一年关键编程语言的趋势做一定的预判。今年由于众所周知的原因&#xff0c;预测地有些晚&#xff0c;我选择在开年的第一天给出我的预测&#xff0c;也算是祝大家…

(Java高级教程)第四章必备前端基础知识-第三节2:JavaScript数组、函数和对象

文章目录一&#xff1a;数组二&#xff1a;函数三&#xff1a;对象一&#xff1a;数组 数组&#xff1a;JavaScript中的数组和Java中的ArrayList有点相似&#xff0c;可以动态扩容&#xff0c;并且由于它是动态类型的语言&#xff0c;所以数组内的元素类型不要求一定是相同的 …

【Git】安装搭建与相关概念

目录 1. 安装 1.1出现安全警告&#xff0c;点击运行 1.2浏览协议&#xff0c;下一步 1.3安装目录&#xff0c;所需要磁盘空间大小&#xff0c;下一步 1.4Git Bash需要安装的&#xff0c;其他默认即可&#xff0c;下一步 1.5开始菜单&#xff0c;下一步 1.6默认编辑器&…

《MySQL高级篇》十三、锁

文章目录1. 概述2. MySQL并发事务访问相同记录2.1 读-读情况2.2 写-写情况2.3 读-写或写-读情况2.4 并发问题的解决方案3. 锁的不同角度分类3.1从数据操作的类型划分:读锁、写锁1. 锁定读2. 写操作3.2 从数据操作的粒度划分:表级锁、页级锁、行锁1. 表锁(Table Lock)① 表级别的…