Semaphore(信号量)
Posted tianqizhi
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Semaphore(信号量)相关的知识,希望对你有一定的参考价值。
Semaphore(信号量)
互斥锁 同时只允许一个线程更改数据,而Semaphore是同时允许一定数量的线程更改数据 ,比如厕所有3个坑,那最多只允许3个人上厕所,后面的人只能等里面有人出来了才能再进去。
互斥锁只有1把锁,信号量有多把锁。
import threading, time def run(n): semaphore.acquire()#信号量获取 time.sleep(1) print("run the thread: %s " % n) semaphore.release()#信号量释放 if __name__ == ‘__main__‘: semaphore = threading.BoundedSemaphore(3) # 声明信号量:最多允许3个线程同时运行 for i in range(20): t = threading.Thread(target=run, args=(i,)) t.start() while threading.active_count() != 1: pass # print threading.active_count() else: print(‘----all threads done---‘) #从运行结果的呈现可以看出,3个3个的执行,一次执行<=3个。
以上是关于Semaphore(信号量)的主要内容,如果未能解决你的问题,请参考以下文章
Linux(内核剖析):31---内核同步之(信号量(semaphore)读写信号量(rw_semaphore))
java 多线程 28 : 多线程组件之 Semaphore 信号量