请问 Python 线程是否可以使用 asyncio 协程代替?
假设我有这么一段代码:
import threadingimport 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