python中的互斥锁

如果没有控制多个线程对同一资源的访问,对数据造成破坏,使得线程运行的结果不可预期。这种现象称为“线程不安全”。

 

线程同步解决问题:

  1. 系统调用t1,然后获取到num的值为0,此时上一把锁,即不允许其他现在操作num
  2. 对num的值进行+1
  3. 解锁,此时num的值为1,其他的线程就可以使用num了,而且是num的值不是0而是1
  4. 同理其他线程在对num进行修改时,都要先上锁,处理完后再解锁,在上锁的整个过程中不允许其他线程访问,就保证了数据的正确性

 

from threading import Thread, Lock

 

num =0  # 资源竞争问题

mutex= Lock()  # 创建一个互斥锁

def fun1():

    global num

    for i in range(1000000):

        mutex.acquire()

        # acquire 首先判断锁的当前状态,如果锁处于上锁状态,则默认处于阻塞等待,

        # 等待直到锁变成未上锁状态的时候,才能继续向下运行

        # 如果一旦发现锁处于未上锁状态,则将锁设置为上锁

        num += 1

        mutex.release()  # 释放锁,表示将锁设置为打开状态

 

def fun2():

    global num

    for i in range(1000000):

        mutex.acquire()

        num += 1

        mutex.release()  # 释放锁,表示将锁设置为打开状态

 

 

t1 =Thread(target=fun1)  # 创建一个线程对象

t2 =Thread(target=fun2)  # 创建一个线程对象

 

t1.start()  # 开启线程的执行

t2.start()

 

t1.join()  # 回收线程资源

t2.join()

 

print(num)

 

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

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

相关文章

R语言第二讲

1、R语言包的概念 R提供了大量开箱即用的功能,但它最激动人心的一部分功能是通过可选模块的下载和安装 来实现的。目前有2500多个①称为包(package)的用户贡献模块可从 http://cran.r-project.org/ web/packages 下载。这些包提供了横跨各种…

LeetCode 1568. 使陆地分离的最少天数(DFS)

文章目录1. 题目2. 解题1. 题目 给你一个由若干 0 和 1 组成的二维网格 grid ,其中 0 表示水,而 1 表示陆地。 岛屿由水平方向或竖直方向上相邻的 1 (陆地)连接形成。 如果 恰好只有一座岛屿 ,则认为陆地是 连通的 &…

python中的非阻塞使用互斥锁

锁定方法acquire可以有一个blocking参数。 如果设定blocking为True,则当前线程会堵塞,直到获取到这个锁为止(如果没有指定,那么默认为True) 如果设定blocking为False,则当前线程不会堵塞 from threading im…

在XML文件中定义动画(1)

① 打开Eclipse&#xff0c;新建Android工程② 在res目录中新建anim文件夹③ 在anim目录中新建一个myanim.xml(注意文件名小写)④ 加入XML的动画代码 <?xml version"1.0" encoding"utf-8"?><set xmlns:android"http://schemas.android…

LeetCode 1569. 将子数组重新排序得到同一个二叉查找树的方案数(DP)

文章目录1. 题目2. 解题1. 题目 给你一个数组 nums 表示 1 到 n 的一个排列。 我们按照元素在 nums 中的顺序依次插入一个初始为空的二叉查找树&#xff08;BST&#xff09;。 请你统计将 nums 重新排序后&#xff0c;统计满足如下条件的方案数&#xff1a;重排后得到的二叉查…

ADS1.2开发环境创建与简要介绍

ADS1.2下建立工程 1.运行ADS1.2集成开发环境&#xff08;CodeWarrior for ARM Developer Suite&#xff09;&#xff0c;点击File|New,在New对话框中&#xff0c;选择Project栏&#xff0c;其中共有7项&#xff0c;ARM Executable Image是ARM的通用模板。选中它即可生成ARM的执…

多线程的全局变量与局部变量

在多线程开发中&#xff0c;全局变量是多个线程都共享的数据&#xff0c;而局部变量等是各自线程的&#xff0c;是非共享的。 from threading import Thread import time classMyThread(Thread): # 重写 构造方法 def __init__(self, num): # Thread.__init__(self) super(MyT…

const类型成员函数与mutable

const类型成员函数与mutable 原文&#xff1a;http://houhualiang.i.sohu.com/blog/view/42619368.htm const类型的成员函数是指使用const关键字进行修饰的类的成员函数。const类型的成员函数对函数内部的操作加以一定的限制&#xff0c;比如不可以对对象的属性进行修改等&…

阿里云 超级码力在线编程大赛初赛 第2场 题目1. 三角魔法

文章目录1. 题目2. 解题1. 题目 题目来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683722506851 2. 解题 采用直线的一般式进行判定 首先要能组成三角形然后是我的位置和第3点在另外两点形成的直线同侧 class Solution { public:/*** param tria…

R语言第四讲 之R语言数据类型

基本类型 通常&#xff0c;在使用任何编程语言进行编程时&#xff0c;您需要使用各种变量来存储各种信息。 变量只是保留值的存储位置。 这意味着&#xff0c;当你创建一个变量&#xff0c;你必须在内存中保留一些空间来存储它们。 您可能想存储各种数据类型的信息&#xff0…

python中的死锁

在线程间共享多个资源的时候&#xff0c;如果两个线程分别占有一部分资源并且同时等待对方的资源&#xff0c;就会造成死锁。 尽管死锁很少发生&#xff0c;但一旦发生就会造成应用的停止响应。下面看一个死锁的例子 from threading import Thread, Lock import time mutex1 …

linux 编译安装apache

1、下载apache、安装apache #wget http://apache.etoak.com//httpd/httpd-2.4.4.tar.gz #tar zxvf httpd-2.4..4.tar.gz2. 安装apache 之前要先安装 apr 和 apr-util apr 下载地址 http://apr.apache.org/download.cgi # wget http://mirrors.cnnic.cn/apache//apr/apr-1…

阿里云 超级码力在线编程大赛初赛 第2场 题目3. 五字回文

文章目录1. 题目2. 解题1. 题目 来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683722506852 2. 解题 注意 a,b,c互不相同 class Solution { public:/*** param s: The given string* return: return the number of Five-character palindrome*/in…

R语言第五讲 之R语言 变量

概述 变量为我们提供了我们的程序可以操作的命名存储。 R语言中的变量可以存储原子向量&#xff0c;原子向量组或许多Robject的组合。 有效的变量名称由字母&#xff0c;数字和点或下划线字符组成。 变量名以字母或不以数字后跟的点开头。 变量名合法性原因var_name2.有效有字…

python中解决死锁的方法

1.添加超时时间&#xff1a; fromthreading import Thread, Lock importtime mutex1 Lock() # 创建一个互斥锁 mutex2 Lock() # 创建一个互斥锁 def fun1(): while True: mutex1.acquire() print("线程1 锁住了mutex1") time.sleep(0.1) result mutex2.acquire(…

[内核摘要] 虚拟文件系统

Linux支持多种文件系统类型的方式和其他类Unix系统类似&#xff0c;通过虚拟文件系统来实现。 对每个读&#xff0c;写或其他操作文件系统的调用函数&#xff0c;内核都用实际支持各种文件系统的函数来代替。 12.1 虚拟文件系统(VFS)的角色 VFS是一个内核软件层&#xff0c;用来…

python之数据库连接

概述 前几日&#xff0c;闲来无事&#xff0c;写了一个python来连接数据库的模板案例&#xff0c;仿照传统MVC的例子。代码如下&#xff1a; DBUtil import pymysqlclass DBUtil:__db None__obj None__init_flag True__cursor Nonedef __new__(cls, *args, **kwargs):if …

python同步应用:多个线程有序执行

可以使用互斥锁完成多个任务&#xff0c;有序的进程工作&#xff0c;这就是线程的同步 from threading import Thread, Lock import time mutex1 Lock() # 创建一个互斥锁 mutex2 Lock() # 创建一个互斥锁 mutex3 Lock() # 创建一个互斥锁 def fun1(): while 1: mutex1…

阿里云 超级码力在线编程大赛初赛 第2场 题目4. 小栖的金字塔(超级卡特兰数+除法求模/乘法逆元)

文章目录1. 题目2. 解题1. 题目 来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683739284070 2. 解题 按道理可以DP暴力求解&#xff0c;但是数据规模太大&#xff0c;会超时的 手算前几项&#xff0c;然后去 oesi 网站查询数列&#xff0c;找到 大…

统计学习之箱线图

箱线图&#xff1a; 箱形图&#xff08;Box-plot&#xff09;又称为盒须图、盒式图或箱线图&#xff0c;是一种用作显示一组数据分散情况资料的统计图。因形状如箱子而得名。在各种领域也经常被使用&#xff0c;常见于品质管理。它主要用于反映原始数据分布的特征&#xff0c;还…