Python实现多线程(二)

本文介绍了Python中多线程的使用,包括信号量的概念和代码示例,条件变量的理解及wait、notify相关函数,事件的机制及set、clear、wait方法,还提供了实例代码演示。
摘要由CSDN通过智能技术生成

目录

一、信号量

1、信号量的概念及理解

2、代码示例

二、条件变量

1、条件变量的概念及理解

2、相关函数

3、代码示例

三、事件

1、事件的概念及理解

2、事件的相关函数

3、代码示例

四、实例代码演示

1、代码示例

2、输出样例

五、参考文章资料


一、信号量

1、信号量的概念及理解

信号量(semaphore)是操作系统用来解决并发中的互斥和同步问题的一种方法。

核心就是控制线程并发数,能同时允许一定数量的线程更改数据。

举个例子,信号量就是一个数值,给出n个信号量,那么将这些信号量给n个线程去运行,且这n个线程同时运行,这n个线程运行结束之后,再给一些线程,并将它们补上来运行,总之,按一定顺序且不耽误各个线程最终都能按照需求去进行。

2、代码示例

import threading
import time
'''定义一个继承线程的类'''
class MyThread(threading.Thread):
    def run(self):
        '''加锁,如果获取信号量的话(用acquire函数来判断),就开始执行'''
        if semaphore.acquire():
            print(self.name)
            time.sleep(1)
            '''解锁,释放信号量'''
            semaphore.release()
'''主函数'''
if __name__=="__main__":
    '''创建锁对象,以下两种方法都可以'''
    semaphore = threading.Semaphore(5)
    '''semaphore = threading.BoundedSemaphore(5)'''
    '''放在一个数组里打印出来'''
    thrs=[]
    for i in range(100):
        thrs.append(MyThread())
    '''将数组内的读取出来然后再打印'''
    for i in thrs:
        i.start()

输出样例:执行该进程,由于semaphore传入的信号量参数为5,所以线程是5个5个一执行,同时在中间插入时间包,将时间打印到控制台上

二、条件变量

1、条件变量的概念及理解

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

可以认为,除了Lock带有的锁定池外,Condition还包含一个等待池,池中的线程处于状态图中的等待阻塞状态,直到另一个线程调用notify()/notifyAll()通知;得到通知后线程进入锁定池等待锁定。

或者这么理解,Condition提供了一种多线程通信机制,假如线程1需要数据,那么线程1就阻塞等待,这时线程2就去制造数据,线程2制造好数据后,通知线程1可以去取数据了,然后线程1去获取数据。

2、相关函数

Condition():

  • acquire(): 线程锁
  • release(): 释放锁
  • wait(timeout): 线程挂起,直到收到一个notify通知或者超时(可选的,浮点数,单位是秒s)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值