请问 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()

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

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

阅读 3.1k
2 个回答

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

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

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题