amarao (amarao_san) wrote,
amarao
amarao_san

multithread python

Вот у меня есть такой код (с упрощениями)
    for entry in task_data:
        thread = threading.Thread(target=job, args=(entry,))
        thread.start()
        thread_list.append(thread)
    for thread in thread_list:
        log.info("Waiting for thread %s" str(thread))
        thread.join()
    log.info("Cycle done")


Предположим, я не ожидаю (по ТЗ), что какой-либо из тредов зависнет. Является ли этот код адекватным?

Другими словами, после того как я сделаю join для всех тредов, они же все будут stopped к моменту "Cycle done"?

Какие неожиданные грабли меня могут ожидать? Предполагается, что job - это сплошное внешнее IO, а математики питона там мало.
Tags: python
Subscribe

  • systemd-networkd, netlink и arp флуд

    Нереально странный баг пофикшен с помощью eBPF затычки. Для меня большой неожиданностью является реакция на него.…

  • Rust soundness

    Каждый раз, когда я сталкиваюсь с маленькими "но" в Rust'е, это ощущение тщательной продуманности. Например, простейшие fold-функции для итераторов:…

  • still_ntp

    В ходе локального мозгового штурма у меня родилась суперидея. Надо написать ntp сервер, который может отдавать указанную дату. Т.е. сказали при…

  • Post a new comment

    Error

    default userpic

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 6 comments