Python 多线程中 time.sleep()和event.wait

time.sleep(n)介绍

参数单位为s,使用该函数会将线程挂起n秒。

举个例子:

import time

print(“111”)

time.sleep(3)

print("222")

程序会在打印111之后等待5S再打印222

我看别的文章说不同线程中的time.sleep()不会相互影响。然而在有个项目中写了两个线程,一个负责数据读取,一个负责数据处理。结果发现time.sleep()还是会影响另一个线程,猜测可能是GIL或者说两个线程中要对同一数据处理造成的阻塞。

另外看到一个event.wait()函数和time.sleep()函数用法一致,但是event.wait()不会去阻塞程序,不用等待线程休眠结束,可以提前终止休眠,且event.wait不受GIL影响。(没有实际用过,看到就积累一下)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python,线程和协程都是用于在程序实现并发执行的机制,但它们的实现方式和使用方法有一些不同。 线程是操作系统级别的概念,它是进程的一部分,在同一个进程的多个线程可以并发执行。Python提供了`threading`模块来支持多线程编程。你可以使用`threading.Thread`类创建并启动一个新线程,也可以使用`threading.Thread`类的`start()`方法来启动线程的执行。此外,你还可以使用`threading.Lock`类来实现线程之间的同步。 下面是一个简单的例子,展示了如何使用线程: ```python import threading def print_numbers(): for i in range(1, 6): print(i) def print_letters(): for letter in 'abcde': print(letter) if __name__ == '__main__': t1 = threading.Thread(target=print_numbers) t2 = threading.Thread(target=print_letters) t1.start() t2.start() t1.join() t2.join() ``` 协程是一种更轻量级的并发编程机制,它基于生成器函数实现。Python提供了`asyncio`模块来支持协程编程。你可以使用`async`关键字来定义一个协程函数,使用`await`关键字来挂起协程的执行,以便让其他协程运行。 下面是一个简单的例子,展示了如何使用协程: ```python import asyncio async def print_numbers(): for i in range(1, 6): print(i) await asyncio.sleep(1) async def print_letters(): for letter in 'abcde': print(letter) await asyncio.sleep(1) if __name__ == '__main__': loop = asyncio.get_event_loop() tasks = [print_numbers(), print_letters()] loop.run_until_complete(asyncio.wait(tasks)) loop.close() ``` 需要注意的是,在Python使用线程和协程时,要注意线程安全和协程之间的同步。例如,在多线程编程,你可以使用锁来保护共享资源,以避免竞争条件。而在协程编程,你可以使用`asyncio.Lock`类来实现协程之间的同步。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值