请问 Python 线程是否可以使用 asyncio 协程代替?

请问 Python 线程是否可以使用 asyncio 协程代替?

假设我有这么一段代码:

import threading

import time

time_list = []

def listen():

last_second = 0

while True:

cur_time = str(int(time.time()))

if not last_second == cur_time:

print('加入 %s' % cur_time)

threading.Thread(target=wait_callback, args=(cur_time,)).start()

last_second = cur_time

time.sleep(0.5)

def wait_callback(cur_time):

"""执行耗时任务"""

time.sleep(2)

print('执行 %s......' % cur_time)

listen()

请问其中的线程能否协程代替?由协程代替执行耗时任务。

这只是一个示例代码,真实环境中使用的双线程队列消费。


回答:

能不能用协程代替,要看这个耗时任务具体是什么,这个任务里相应的代码和相关的库也要是协程的写法。例如本来里面可能是一个使用requests库来发送网络请求的,改成协程可以用aiohttp,相应的写法都要改。


回答:

首先要搞清楚概念和原理,线程、进程、协程是不同的概念和原理。
简单说进行就是不同的cpu各自执行。进程是不同的进程同时执行。协程是一个进程一个线程,通过上下文切换避免io等待。

应用上,如果你的是io密集型,比如大量文件操作和网络请求可以使用协程实现来减少等待时间。

以上是 请问 Python 线程是否可以使用 asyncio 协程代替? 的全部内容, 来源链接: utcz.com/a/158140.html

回到顶部