线程池的执行是异步的吗?(希望有大佬能解说一下!)

 

 今天没事写了个自定义线程池,发现执行顺序是异步的(下面是加了线程睡眠1milis)

 加了睡眠后的结果

 有大佬能帮我解释一下吗

创建异步任务可以使用Python的asyncio模块来实现。asyncio提供了一种协程的方式,可以让我们方便地创建异步任务。以下是一个简单的异步任务的示例代码: ```python import asyncio async def my_coroutine(): print("start coroutine") await asyncio.sleep(1) print("end coroutine") loop = asyncio.get_event_loop() loop.run_until_complete(my_coroutine()) ``` 这个示例定义了一个协程函数`my_coroutine`,使用`async def`关键字定义。这个协程函数打印一条消息,等待一秒钟,然后再打印一条消息。 在主函数中,我们使用`asyncio.get_event_loop()`函数获取一个事件循环对象,并使用`run_until_complete`方法运行协程函数。这将会执行协程函数中的所有代码,并等待协程函数完成。 如果我们需要同时执行多个异步任务,我们可以使用`asyncio.gather()`函数将它们打包成一个协程,并使用`run_until_complete()`方法运行这个协程。 如果我们需要将异步任务提交到线程池执行,我们可以使用`asyncio.to_thread()`函数。这个函数可以将一个阻塞的函数转换为一个线程池中的异步任务。以下是一个示例代码: ```python import asyncio import concurrent.futures def blocking_function(): print("start blocking function") time.sleep(1) print("end blocking function") async def my_coroutine(): print("start coroutine") await asyncio.to_thread(blocking_function) print("end coroutine") loop = asyncio.get_event_loop() with concurrent.futures.ThreadPoolExecutor() as pool: loop.set_default_executor(pool) loop.run_until_complete(my_coroutine()) ``` 这个示例定义了一个阻塞函数`blocking_function`,这个函数会等待一秒钟。在协程函数`my_coroutine`中,我们使用`asyncio.to_thread()`函数将`blocking_function`转换为一个线程池任务,并在协程函数中执行。 在主函数中,我们使用`concurrent.futures.ThreadPoolExecutor()`创建一个线程池,并使用`loop.set_default_executor()`方法将它设置为默认的执行器。这将会使得所有使用`asyncio.to_thread()`函数创建的任务都在这个线程池执行。最后,我们使用`loop.run_until_complete()`方法执行协程函数。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值