Python高级学习第四课 2022-01-10

一,多线程

信号量:是一种用于提供不同进程之间或者一个给定的不同线程间同步手段的原语。信号量多用于进程间的同步与互斥。

信号量是解决互斥共享资源的同步问题而引入的机制。

一个信号量管理一个内部计数器,该计数器因acquire()方法的调用而递减,因 release()方法的调用而递增。 计数器的值永远不会小于零;当acquire()方法发现计数器为零时,将会阻塞,直到其它线程调用release()方法。

semaphore = threading.Semaphore()

acquire()#设置线程锁
release()#释放线程锁

 一个例子:

import threading
import time


def run(n, x):
    semaphore.acquire()#设置线程锁
    print(n)
    time.sleep(x)#令当前执行的线程暂停1秒后再继续执行
    semaphore.release()#释放线程锁


if __name__ == '__main__':
    semaphore = threading.Semaphore(5)#创建信号量对象,最多允许5个线程同时运行
    for i in range(16):
        t = threading.Thread(target=run, args=(i,i))  # 创建线程
        t.start()  # 启动线程活动

条件变量:通常与一个锁关联。需要在多个Contidion中共享一个锁时,可以传递一个Lock/RLock实例给构造方法,否则它将自己生成一个RLock实例。

线程通过acquire获得Condition对象,当调用wait方法时,线程会释放Condition内部的锁并进入blocked状态,同时在waiting池中记录这个线程。当调用notify方法时,Condition对象会从waiting池中挑选一个线程,通知其调用acquire方法尝试取到锁。

acquire()#线程锁

release()#释放锁

wait(timeout)#线程挂起(阻塞状态),直到收到一个notify通知或者超时才会被唤醒继续运行。wait()#必须在已获得Lock前提下才能调用,否则会触发RuntimeError;

notify(n=1)#通知其他线程,那些挂起的线程接到这个通知之后会开始运行,缺省参数,默认是通知一个正等待通知的线程,最多则唤醒n个等待的线程。
notify()#必须在已获得Lock前提下才能调用,否则会触发RuntimeError,

notifyAll()#当wait状态线程比较多时,notifyAll通知所有线程

事件:事件处理的机制:全局定义了一个内置标志Flag,如果Flag值为 False,那么当程序执行 event.wait方法时就会阻塞,如果Flag值为True,那么event.wait 方法时便不再阻塞。

Event其实就是一个简化版的 Condition。Event没有锁,无法使线程进入同步阻塞状态。

事件event中有一个全局内置标志Flag,值为 True 或者False。使用wait()函数的线程会处于阻塞状态,此时Flag指为False,直到有其他线程调用set()函数让全局标志Flag置为True,其阻塞的线程立刻恢复运行,还可以用isSet()函数检查当前的Flag状态。

set()#将标志设为True,并通知所有处于等待阻塞状态的线程恢复运行状态。

clear()#将标志设为False。

wait(timeout)#如果标志为True将立即返回,否则阻塞线程至等待阻塞状态,等待其他线程调用set()。

isSet()#获取内置标志状态,返回True或False。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值