версии питона 3.X передача управления OS от одного потока к другому происходила через каждые 100 "элементарных команд".
'''Lary Hastings (a core CPython developer): The way Python threads work with the GIL is with a simple counter. With every 100 byte codes executed the GIL is supposed to be released by the thread currently executing in order to give other threads a chance to execute code''''
Позже, этот механизм заменили на передачу управления каждые 5 миллисекунд. Я где-то это читал, но подтверждение этой информации не нашел в доке. Если это действительно так, то тогда у меня возникает глупый вопрос: Почему есть возможность отправлять больше чем 200 http requests запросов, ведь кажется что передача управления может быть не чаще чем 1000 / 5 раз в секунду? Накидал примерный код который по моей логике не может увеличивать переменную counter больше чем на 200 в секунду, но почему-то это делает. (https://pastebin.com/WH4FK8Lx). Подскажите, где я ошибаюсь?
https://asvetlov.blogspot.com/2011/07/gil.html
Потрясающая статья, сильно открыла глаза о GIL и потоках в целом, спасибо огромное! Еще прочел презентацию Дэвида Бизли на которую ссылается Андрей в своей статье, тоже много полезной информации узнал. Я понял что переключение между потоками не всегда происходит каждые 5 мс, а и в любой другой момент когда другой поток отдает управление. Хотя ситуация с всего лишь 200 переключениями в сек возможна если все потоки CPU-bound и не хотят сами отдавать управление. Еще раз спасибо!!
Обсуждают сегодня