1、信号量
信号量Semaphore是一个计数器,控制对公共资源或者临界区域的访问量,信号量可以指定同时访问资源或者进入临界区域的进程数。每次有一个进程获得信号量时,计数器-1,若计数器为0时,其他进程就停止访问信号量,一直阻塞直到其他进程释放信号量。举个例子来说就是,比如厕所有3个坑,那最多只允许3个人上厕所,后面的人只能等里面有人出来了才能再进去。
总的来说信号量也是一把锁,用来控制线程并发数的多少。
示例:
import threading
import time
def run(n):
# 上锁
semaphore.acquire()
print(n)
time.sleep(2)
# 线程释放
semaphore.release()
if __name__ == '__main__':
# 定义信号量为,一次并发限制为5个
semaphore = threading.Semaphore(5)
for i in range(50):
t = threading.Thread(target=run, args=(i, ))
t.start()
代码结果
2、条件变量
有了前面提到的互斥锁,为什么还需要条件变量呢,当然是由于有些复杂问题互斥锁搞不定了。Python
提供的Condition
对象提供了对复杂线程同步问题的支持。