进程锁(互斥锁)

Posted sun-10387834

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了进程锁(互斥锁)相关的知识,希望对你有一定的参考价值。

3:# 抢票示例
import json
import time
from multiprocessing import Process,Lock

def search(i):
    with open(ticket,encoding=utf-8) as f:
        ticket = json.load(f)
    print(%s :当前的余票是%s张%(i,ticket[count]))

def buy_ticket(i):
    with open(ticket,encoding=utf-8) as f:
        ticket = json.load(f)
    if ticket[count]>0:
        ticket[count] -= 1
        print(%s买到票了%i)
    time.sleep(0.1)
    with open(ticket, mode=w,encoding=utf-8) as f:
        json.dump(ticket,f)

def get_ticket(i,lock):
    search(i)
    with lock:   # 代替acquire和release 并且在此基础上做一些异常处理,保证即便一个进程的代码出错退出了,也会归还钥匙
        buy_ticket(i)


if __name__ == __main__:
    lock = Lock()     # 互斥锁
    for i in range(10):
        Process(target=get_ticket,args=(i,lock)).start()


1:# Lock解析
# import time # from multiprocessing import Lock,Process # def func(i,lock): # lock.acquire() # 拿钥匙 # print(‘被锁起来的代码%s‘%i) # lock.release() # 还钥匙 # time.sleep(1) # # if __name__ == ‘__main__‘: # lock = Lock() # for i in range(10): # p = Process(target=func,args=(i,lock)) # p.start() 2:# from multiprocessing import Lock # 互斥锁 不能再同一个进程中连续acquire多次
# lock = Lock() # lock.acquire() # print(1) # lock.release() # lock.acquire() # print(2) # lock.release()

存票文件:

{"count": 0}

 

以上是关于进程锁(互斥锁)的主要内容,如果未能解决你的问题,请参考以下文章

Python11/12--GIL/互斥锁/进程池

进程互斥锁--二值信号量

并发编程互斥锁

pthread mutex 进程间互斥锁

忙等待中的互斥

互斥锁自旋锁读写锁和条件变量