【操作系统知识】线程间通信

本文详细介绍了线程间通信的各种方法,包括互斥锁、信号量、条件变量、事件和消息队列。互斥锁确保资源在同一时刻只被一个线程访问,而信号量用于限制资源的并发访问数量。条件变量则提供了更灵活的同步机制,事件对象简化了线程间的同步,并且消息队列允许线程安全地传递数据。
摘要由CSDN通过智能技术生成

9. 线程间通信

(1) 互斥锁

互斥锁为资源引入一个状态:锁定/非锁定。某个线程要更改共享数据时,先将其锁定,此时资源的状态为“锁定”,其他线程不能更改;直到该线程释放资源,将资源的状态变成“非锁定”,其他的线程才能再次锁定该资源。互斥锁保证了每次只有一个线程进行写入操作,从而保证了多线程情况下数据的正确性。

"""
#创建锁
mutex = threading.Lock()
#锁定
mutex.acquire([timeout])
#释放
mutex.release()
"""
import threading

money = 0

def order(n):
    global money
    money = money + n
    money = money - n

class MyThread(threading.Thread):
    def __init__(self, thread_name):
        threading.Thread.__init__(self, name='线程' + thread_name)
        self.thread_name = int(thread_name)

    def run(self):
        for i in range(1000000):
            lock.acquire()  # 加锁
            order(self.thread_name)
            lock.release()  # 释放

if __name__ == '__main__':
    lock = threading.Lock()
    t1 = MyThread('1')
    t2 = MyThread('10')
    t1.start()
    t2.start()
    t1.join()
    t2.join()
    print(money)

# 结果
'''
0
'''

为了支持在同一线程中多次请求同一资源,python提供了“可重入锁”:threading.RLock。RLock内部维护着一个Lock和一个counter变量,counter记录了acquire的次数,从而使得资源可以被多次acquire。直到一个线程所有的acquire都被release,其他的线程才能获得资源。acquire() 和 release() 必须成对出现,也就是说加了几把锁就得释放几把锁。

import threading
import time

num = 0
mutex = threading.RLock()

class MyThread(threading.Thread):
    def run(self
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值