python_examples/thread_pool_patterns/asyncio_with_thread_pool.py

45 lines
1.2 KiB
Python
Raw Permalink Normal View History

2023-09-15 12:55:39 -04:00
#!/usr/bin/env python3
2023-09-16 16:51:31 -04:00
"""thread_pool.py
----------------
2023-09-15 12:55:39 -04:00
This module demonstrates the use of asyncio to handle asynchronous and blocking
functions in Python. The module contains three functions: a blocking function
that simulates a long-running process with `time.sleep`, an asynchronous
function that demonstrates asyncio's sleep, and a main function that runs
both the blocking and async functions concurrently using a ThreadPoolExecutor
for the blocking function.
"""
import asyncio
from concurrent.futures import ThreadPoolExecutor
import time
def blocking_function():
2024-05-12 22:40:34 -04:00
print("Blocking function started!")
time.sleep(5)
2023-09-15 12:55:39 -04:00
return "Blocking function completed!"
async def async_function():
print("Async function started!")
await asyncio.sleep(1)
print("Async function completed!")
async def main():
loop = asyncio.get_event_loop()
executor = ThreadPoolExecutor()
2024-05-12 22:40:34 -04:00
async_task = loop.create_task(async_function())
2023-09-15 12:55:39 -04:00
result = await loop.run_in_executor(executor, blocking_function)
print(result)
await async_task
if __name__ == "__main__":
2024-05-12 22:40:34 -04:00
loop = asyncio.get_event_loop()
main_task = loop.create_task(main())
loop.run_until_complete(main_task)