python_examples/thread_pool_patterns/submit_wait_for_all.py

43 lines
1.0 KiB
Python
Raw Permalink Normal View History

2024-05-12 22:40:34 -04:00
#!/usr/bin/env python3
from time import sleep
from random import randint
from concurrent.futures import ThreadPoolExecutor, wait, Future
results: list[int] = []
2024-05-12 22:42:11 -04:00
2024-05-12 22:40:34 -04:00
def add_one(number: int) -> int:
print(number)
2024-05-12 22:42:11 -04:00
sleep(randint(0, 2))
2024-05-12 22:40:34 -04:00
return number + 1
def main() -> None:
executor = ThreadPoolExecutor(32)
futures: list[Future] = [executor.submit(add_one, number) for number in range(10)]
wait(futures)
print("Done waiting!")
for future in futures:
print(future.result())
print("All done!")
futures: list[Future] = [executor.submit(add_one, number) for number in range(10)]
executor.shutdown()
print("Done waiting!")
for future in futures:
print(future.result())
print("All done!")
with ThreadPoolExecutor() as executor:
2024-05-12 22:42:11 -04:00
futures: list[Future] = [
executor.submit(add_one, number) for number in range(10)
]
2024-05-12 22:40:34 -04:00
print("Done waiting!")
for future in futures:
print(future.result())
print("All done!")
if __name__ == "__main__":
main()