CoolPython
4.47K subscribers
20 photos
44 links
Канал об основах Python и хороших практиках разработки. Создаём системность в обрывочных знаниях.

Тем, кто хочет понимать, что пишет!
Download Telegram
Вау, в Python будет можно по желанию отключить GIL. В мейн буквально пару часов назад вмержили эту настройку

https://github.com/python/cpython/pull/116338

GIL (Global Interpreter Lock) — это механизм в CPython, который предотвращает одновременное выполнение нескольких потоков.

Это всю дорогу означало, что даже если мы пишем программу на Python как многопоточную, то в любой момент времени может выполняться только один тред.

С одной стороны, это ограничивало возможности параллельного выполнения кода даже на многоядерных процессорах. С другой, облегчало управление памятью в Python: такое решение исключает все особенности многопоточного программирования и делает проще работу программиста.

Наличие GIL годами было предметом дебатов и критики из-за ограничений на многопоточность. Я рада, что парадигма однопоточности Python наконец сдвигается: это реально изменит разработку на этом языке.
🔥29👍63🤔2🤯2🐳2
Вы, наверное, знаете, что из-за того, что числа в памяти представлены в двоичной форме, в Python есть ошибка вида

print(0.1 + 0.2)
# 0.30000000000000004


В Python модуль decimal поддерживает точную арифметику десятичных чисел. Она важна в областях, требующих высокой точности, например, в финансах или научных расчетах.

А вот кто скажет, почему возникает разница в примерах ниже?

1️⃣

from decimal import Decimal

a = Decimal(0.1)
b = Decimal(0.2)
print(a + b)
# 0.3000000000000000166533453694


2️⃣

a = Decimal('0.1')
b = Decimal('0.2')
print(a + b)
# 0.3


Жду ваши ответы в комментариях!
👍20🤯103😁2
Исторический момент: выходит Python 3.14 и они там отменяют GIL. Дожили, поздравляю нас!🎉

Всем, кто хоть раз в жизни писал код в несколько тредов на питоне и ломал голову, почему не ускоряется😁 Это ваш день!

Глобальная блокировка десятилетиями неявно ограничивала интерпретатор, а мы пользовались multiprocessing-ом, расширениями на плюсах и всякими костылями, чтобы задействовать все ядра процессора.

Это первый стабильный (не экспериментальный) релиз, в котором интерпретатор без GIL поддерживается официально. Теперь:
- появляются тру параллельные треды на чистом питоне,
- Async начинает работать с тредами,
- реализовано нормальное масштабирование на нескольких ядрах для data-intensive задач, машинки и прочих симуляций.

Это не очередной релиз, а прям веха в эволюции языка.

Как человек, который много лет живет питоном, я реально в восторге.

Пока, GIL! Скучать не будем.

———
UPD
⚠️ Ладно, надо уточнить, что так-то
- free-threaded режим не включён по умолчанию: такой питон нужно собирать со специальным флагом
- и большинство важных либ пока с этим режимом несовместимы

Но все равно круто
Please open Telegram to view this post
VIEW IN TELEGRAM
🤔2522🔥7🎉6😁2🐳1