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()
相关推荐
学测绘的小杨19 小时前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
zzzzzz3101 天前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐1 天前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
兵慌码乱2 天前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot2 天前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
顾林海2 天前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱2 天前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
曲幽2 天前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
荣码2 天前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱3 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理