python 笔记之线程同步和死锁

同步:

复制代码
共享数据:
如果多个线程共同对某个数据修改,则可能出现不可预测的结果,为了保证数据的正确性,需要对多个数据进行同步
同步:一个一个的完成,一个做完另一个才能进来
效率会降低
使用Thread对象的Lock和RLock可以实现简单的线程同步,这两个对象都有acquire方法和release方法
对于那些需要每次只允许一个线程操作的数据,可以将其操作放到acquire和release方法之间

多线程的优势在于可以同时运行多个任务,但是当线程需要共享数据时,可能存在数据不同步的问题。为了避免这种情况,
引入了锁的概念
lock=threading.Lock()
lock.acquire()请求得到锁
lock.release()释放锁
只要不释放其它的线程都无法进入运行状态
复制代码
import threading
import random
import time

lock=threading.Lock()
list1=[0]*10

def task1():
    #获取线程锁,如果已经上锁了,则等待锁的释放
    lock.acquire() #阻塞
    for i in range(len(list1)):
        list1[i]=1
        time.sleep(1)
    lock.release()

def task2():
    lock.acquire()
    for i in range(len(list1)):
        print('---->',list1[i])
        time.sleep(1)
    lock.release()

if __name__=='__main__':
    t1=threading.Thread(target=task1,name='task1')
    t2=threading.Thread(target=task2,name='task2')

    t1.start()
    t2.start()
    t2.join()
    t1.join()
    print(list1)

死锁:

复制代码
开发过程中使用线程,在线程间共享多个资源的时候
如果两个线程分别占有一部分资源并且同时等待对方的资源,就会造成死锁
尽管死锁很少发生,但是一旦发生就会造成应用的停止响应,程序不做任何事情
避免死锁:
解决:
1.重构代码
2.使用timeout
复制代码
from threading import Thread,Lock
import time
lock1=Lock()
lock2=Lock()
class MyThread(Thread):
    def run(self):
        if lock1.acquire():#如果可以获取锁那么返回True
            print(self.name +"获取了A锁")
            time.sleep(0.1)
            if lock2.acquire(timeout=5):
                print(self.name+"又获得了B锁")
                lock2.release()
            lock1.release()

class Mythread2(Thread):
    def run(self):
        if lock2.acquire():  # 如果可以获取锁那么返回True
            print(self.name + "获取了B锁")
            time.sleep(0.1)
            if lock1.acquire(timeout=5):
                print(self.name + "又获得了A锁")
                lock1.release()
            lock2.release()
if __name__=="__main__":
    t1=MyThread()
    t2=Mythread2()
    t1.start()
    t2.start()
相关推荐
m0_514520577 分钟前
MySQL索引优化后性能没提升_通过EXPLAIN查看索引命中率
jvm·数据库·python
H Journey18 分钟前
Python 国内pip install 安装缓慢
python·pip·install 加速
Polar__Star1 小时前
如何在 AWS Lambda 中正确使用临时凭证生成 S3 预签名 URL
jvm·数据库·python
三棱球2 小时前
App逆向学习笔记(三)——Android开发入门课
android·笔记
m0_743623922 小时前
React 自定义 Hook 的命名规范与调用规则详解
jvm·数据库·python
handler012 小时前
拒绝权限报错!三分钟掌握 Linux 权限管理
linux·c语言·c++·笔记·学习
FreakStudio2 小时前
无硬件学LVGL—定时器篇:基于Web模拟器+MicroPython速通GUI开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
阿Y加油吧3 小时前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
gCode Teacher 格码致知3 小时前
Python提高:pytest的简单案例-由Deepseek产生
python·pytest
ouliten3 小时前
cuda编程笔记(39)--Asynchronous Barriers(异步屏障)
笔记·cuda