Python多线程与互斥锁模拟抢购余票的示例

一、示例代码:

python 复制代码
from threading import Thread
from threading import Lock
import time

n = 100                                    # 共100张票


def task():
    global n
    mutex.acquire()                         # 上锁
    temp = n
    time.sleep(0.1)
    n = temp - 1
    print('购票成功,剩余%d张余票!' % n)
    mutex.release()                         # 释放锁


if __name__ == '__main__':
    mutex = Lock()                          # 实例化Lock类
    thread_list = []                        # 初始化列表
    for i in range(100):
        t = Thread(target=task)             # 实例化线程类
        thread_list.append(t)               # 线程实例加入列表
        t.start()                           # 创建线程
    for t in thread_list:
        t.join()                            # 等待子线程结束

二、方法注释

threading模块中使用Lock类方便的处理锁定。Lock类的两个方法:acquire()上锁与release()释放锁。

三、代码说明:

创建100个线程,全部执行task函数,为解决资源竞争问题,使用mutex.acquire()方法实现资源的锁定,第一个获取资源的线程锁定后,其他线程等待mutex.release()解锁释放资源。所以每次只有一个线程执行task()函数。

四、运行结果:

相关推荐
leo__5206 小时前
MATLAB高斯背景建模与目标提取(人体检测)
开发语言·人工智能·matlab
m0_560396476 小时前
C++中的享元模式
开发语言·c++·算法
深藏功yu名6 小时前
Day24(进阶篇):向量数据库 Chroma_FAISS 深度攻坚 —— 索引优化、性能调优与生产级落地
数据库·人工智能·python·ai·agent·faiss·chroma
2501_924952696 小时前
分布式缓存一致性
开发语言·c++·算法
njidf7 小时前
趣味项目与综合实战
jvm·数据库·python
李昊哲小课7 小时前
PyMySQL完整教程
服务器·数据库·python·pymysql
sqyno1sky7 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
Yupureki7 小时前
《Linux系统编程》12.基础IO
linux·运维·c语言·开发语言·数据库·c++
淮北4947 小时前
bash下好用的快捷键以及linux常用指令
linux·开发语言·ubuntu·bash
belldeep7 小时前
python:spaCy 源代码解析,性能优化方法
python·性能优化·cython·spacy