Я застрял при попытке многопоточности с использованием ThreadPoolExecutor, в результате чего выполнение должно быть безопасно остановлено, если один из процессов соответствует критериям, поэтому оставшиеся потоки не нужно завершать.
У меня есть следующая концепция, но она не работает, она просто работает:
import time, sys
from concurrent.futures import ThreadPoolExecutor
data = {"future1": 'blank', "future2": 'blank', "future3": 'blank'}
def function1(n):
global data #not sure if this is necessary, as it seems to be able to access this anyway?
print(n)
time.sleep(1)
data['future1'] = n
def function2(n):
global data
print(n)
time.sleep(2)
data['future2'] = n
def function3(n):
global data
print(n)
time.sleep(3)
data['future3'] = n
with ThreadPoolExecutor(max_workers=4) as executor:
while True:
future1=executor.submit(function1, 'test1')
future2=executor.submit(function2, 'test2')
future3=executor.submit(function3, 'test3')
if data['future2']!='blank':
executor.shutdown(wait=False)
sys.exit()
Не уверен, что я делаю не так, любая помощь будет оценена.