@tgappsupdates · Post #19660 · 06.04.2026 г., 21:16
DrKLO/Telegram/master • 009e973 • 42 files, +2702/-821 update to 12.6.4 (6666) #android
Hashtags
TGINSIGHT SIMILAR POSTS
Изходен канал @clockstackwheels · Post #721 · 26.12
Почему я люблю языки с сильной системой типов, проверяемой статическим анализом кода — хорошо написанная программа является своей собственной спецификацией и позволяет выражать через язык программирования законы существования предметной области. Когда-то давно я писал на ActionScript. Там была система типов, но вот десериализация JSON'ов по-умолчанию была в какой-то общий Object, к полям которого нужно было обращаться ["по_строковому_имени"]. В один момент мне потребовалось написать что-то на C#, который я совсем не знал, я стал гуглить, как десериализовать JSON, и с удивлением обнаружил кучу советов заранее объявить класс со всеми нужными полями и десериализовать в него. "Какой ужас!", — подумал я тогда, — "Это же дико неудобно! А если я не знаю полей JSON? А если их много? Отвратительный язык!" Теперь то я прекрасно понимаю, что JSON это контракт, и что правильная десериализация только такая и должна быть, и что в хорошем API в одном поле никогда не бывает данных принципиально разных типов, и так далее. Нет, если вы набиваете вечерами пет-проект или сидите бессонную ночь на хакатоне, нет ничего плохого в том, чтобы взять простой язык с динамическими типами вроде JavaScript или Python, не требующий описывать данные. Но вот в энтерпрайзе, особенно когда над одним проектом работает много людей (а бывает это очень часто) — хорошее использование системы типов убережёт разработчиков от огромного количества ошибок, будет бить их по рукам, когда они пытаются сделать что-то не то, и будет подсказывать, когда они не уверены в чём-то. С помощью статической типизации можно на уровне кода обозначить правила, по которым ведёт себя предметная область вашей программы в реальном мире. Разработчику не только будет сложно их нарушить, но он ещё и станет узнавать какие-то вещи, которые мог не знать раньше. Например, если мы делаем медицинскую CRM, и больница заводит новых пациентов только тогда, когда знает их группу крови, мы можем объявить тип "Пациент" (или, если точнее, "Карта пациента") и запретить создавать экземпляры этого типа, не передав в конструктор группу крови (которая, в свою очередь, тоже является типом, вероятнее всего ValueObject'ом). Если новый программист пришёл в проект, он, во-первых, не сможет записать в БД некорректную карту пациента. Понятно, мы не учитываем случаи, когда новый программист переделывает модели предметной области — это будет хорошо видно на кодревью. А, во-вторых, даже если ему никто не сказал, что пациенты должны быть с группой крови, он узнает это из кода. И уже будет понимать, что в тех процессах реальной жизни, которые он описывает кодом, карта пациента создаётся только при наличии группы крови. А, значит, нужно искать какой-то способ сначала эту группу крови получить, и только потом создавать карту. Программирование моделирует реальный процесс. В настоящей работе даже на языках с типами, конечно, без должного контроля можно написать что угодно. Нужна управленческая воля, компетентность руководства, понимание опасности техдолга, в идеале отдельные должности для архитекторов, опытные лиды и старшие разработчики. Но когда всё это есть, можно отсекать много проблем ещё на старте и проще погружать новичков. #dev
Hashtags
Търсене: #android
@tgappsupdates · Post #19660 · 06.04.2026 г., 21:16
DrKLO/Telegram/master • 009e973 • 42 files, +2702/-821 update to 12.6.4 (6666) #android
Hashtags
@tgappsupdates · Post #19651 · 05.04.2026 г., 12:01
DrKLO/Telegram/master • f1af68f • 8 files, +672/-6 update to 12.6.3 (6657) #android
Hashtags
@tgappsupdates · Post #19650 · 05.04.2026 г., 11:46
DrKLO/Telegram/master • 8e10b3f • 22 files, +236/-59 update to 12.6.1 (6653) DrKLO/Telegram/master • fb98f15 • 12 files, +164/-226 update to 12.6.2 (6655) #android
Hashtags
@tgappsupdates · Post #19649 · 05.04.2026 г., 11:31
DrKLO/Telegram/master • f6dd434 • 44 files, +1097/-458 update to 12.5.2 (6597) DrKLO/Telegram/master • 21bdbae • 300 files, +41747/-18219 update to 12.6.0 (6644) #android
Hashtags
@tgappsupdates · Post #19556 · 08.03.2026 г., 20:01
DrKLO/Telegram/master • 1771f5d • 143 files, +7732/-2066 update to 12.5.0 (6573) DrKLO/Telegram/master • ce8c61c • 33 files, +485/-166 update to 12.5.1 (6580) #android
Hashtags
@tgappsupdates · Post #19555 · 08.03.2026 г., 19:46
DrKLO/Telegram/master • 9fdd7fa • 55 files, +1740/-698 update to 12.4.2 (6526) DrKLO/Telegram/master • 5e37155 • 4 files, +56/-6 update to 12.4.3 (6527) #android
Hashtags
@tgappsupdates · Post #19434 · 14.02.2026 г., 13:01
DrKLO/Telegram/master • fa4e8aa • 300 files, +41656/-21387 update to 12.4.0 (6506) DrKLO/Telegram/master • 3581a10 • 26 files, +444/-222 update to 12.4.1 (6510) #android
Hashtags
@tgappsupdates · Post #19322 · 15.01.2026 г., 15:31
DrKLO/Telegram/master • d7deedf • 6 files, +105/-33 update to 12.3.1 (6385) #android
Hashtags
@tgappsupdates · Post #19321 · 15.01.2026 г., 15:16
DrKLO/Telegram/master • 28e25a4 • 152 files, +5099/-1270 update to 12.3.0 (6377) #android
Hashtags
@tgappsupdates · Post #19320 · 15.01.2026 г., 15:01
DrKLO/Telegram/dev2 • 80aa0d7 • 300 files, +24278/-14132 Redesign WIP #android
Hashtags
@tgappsupdates · Post #19157 · 08.12.2025 г., 17:16
DrKLO/Telegram/master • 5390162 • 12 files, +236/-200 update to 12.2.9 (6337) DrKLO/Telegram/master • fff7c8d • 9 files, +31/-8 update to 12.2.10 (6341) #android
Hashtags
@tgappsupdates · Post #19156 · 08.12.2025 г., 17:01
DrKLO/Telegram/master • d1a53bb • 45 files, +1581/-730 update to 12.2.6 (6318) DrKLO/Telegram/master • 8201e36 • 10 files, +40/-38 update to 12.2.7 (6323) DrKLO/Telegram/master • cf701fb • 115 files, +8761/-996 update to 12.2.8 (6336) #android
Hashtags