Итак, я новичок в python и работаю над обработчиком событий файловой системы. Я наткнулся на watchdog api и там увидел код многопоточности, который не могу понять.
Вот код, опубликованный на их сайте:
import sys
import time
import logging
from watchdog.observers import Observer
from watchdog.events import LoggingEventHandler
if __name__ == "__main__":
logging.basicConfig(level=logging.INFO,
format='%(asctime)s - %(message)s',
datefmt='%Y-%m-%d %H:%M:%S')
path = sys.argv[1] if len(sys.argv) > 1 else '.'
event_handler = LoggingEventHandler()
observer = Observer()
observer.schedule(event_handler, path, recursive=True)
observer.start()
try:
while True:
time.sleep(1)
except KeyboardInterrupt:
observer.stop()
observer.join()
Этот код выполняет бесконечный цикл и прослушивает некоторую папку и записывает то, что видит, в консоль. Мое сомнение находится в нижней части кода.
Итак, вы запускаете наблюдатель. Затем попросите его перейти в бесконечный цикл, пока не будет выполнено какое-либо нажатие клавиши. Я предполагаю, что где-то в коде «observer.start()» они также устанавливают daemon=True. После некоторого нажатия клавиши программа выходит из цикла и останавливает наблюдатель. В API сторожевого таймера определение stop() говорит, что оно останавливает поток демона.
1) Затем он выполняет соединение(). Но зачем нужен этот джойн. Я уже остановил поток демона. Разве join() не означает, что нужно дождаться остановки всех потоков, а затем и только тогда выйти из программы. Могу ли я удалить join() из кода. После того, как я удалил его, моя программа все еще работает правильно.
2) Я также не понимаю необходимости сна (1) внутри цикла while. Что произойдет, если я просто поставлю туда оператор «pass». Я предполагаю, что цикл while будет потреблять больше ресурсов??? И причина в том, что мы установили время сна как 1 секунду, а не 2-3 секунды, потому что в худшем случае пользователю, возможно, придется ждать 2-3 секунды, пока программа закроется. Но я могу ошибаться.