TGTGInsightтелеграм анализLIVE / telegram public index
← Такты, стеки, два колеса

TGINSIGHT SIMILAR POSTS

Намери подобно съдържание

Изходен канал @clockstackwheels · Post #721 · 26.12

Почему я люблю языки с сильной системой типов, проверяемой статическим анализом кода — хорошо написанная программа является своей собственной спецификацией и позволяет выражать через язык программирования законы существования предметной области. Когда-то давно я писал на ActionScript. Там была система типов, но вот десериализация JSON'ов по-умолчанию была в какой-то общий Object, к полям которого нужно было обращаться ["по_строковому_имени"]. В один момент мне потребовалось написать что-то на C#, который я совсем не знал, я стал гуглить, как десериализовать JSON, и с удивлением обнаружил кучу советов заранее объявить класс со всеми нужными полями и десериализовать в него. "Какой ужас!", — подумал я тогда, — "Это же дико неудобно! А если я не знаю полей JSON? А если их много? Отвратительный язык!" Теперь то я прекрасно понимаю, что JSON это контракт, и что правильная десериализация только такая и должна быть, и что в хорошем API в одном поле никогда не бывает данных принципиально разных типов, и так далее. Нет, если вы набиваете вечерами пет-проект или сидите бессонную ночь на хакатоне, нет ничего плохого в том, чтобы взять простой язык с динамическими типами вроде JavaScript или Python, не требующий описывать данные. Но вот в энтерпрайзе, особенно когда над одним проектом работает много людей (а бывает это очень часто) — хорошее использование системы типов убережёт разработчиков от огромного количества ошибок, будет бить их по рукам, когда они пытаются сделать что-то не то, и будет подсказывать, когда они не уверены в чём-то. С помощью статической типизации можно на уровне кода обозначить правила, по которым ведёт себя предметная область вашей программы в реальном мире. Разработчику не только будет сложно их нарушить, но он ещё и станет узнавать какие-то вещи, которые мог не знать раньше. Например, если мы делаем медицинскую CRM, и больница заводит новых пациентов только тогда, когда знает их группу крови, мы можем объявить тип "Пациент" (или, если точнее, "Карта пациента") и запретить создавать экземпляры этого типа, не передав в конструктор группу крови (которая, в свою очередь, тоже является типом, вероятнее всего ValueObject'ом). Если новый программист пришёл в проект, он, во-первых, не сможет записать в БД некорректную карту пациента. Понятно, мы не учитываем случаи, когда новый программист переделывает модели предметной области — это будет хорошо видно на кодревью. А, во-вторых, даже если ему никто не сказал, что пациенты должны быть с группой крови, он узнает это из кода. И уже будет понимать, что в тех процессах реальной жизни, которые он описывает кодом, карта пациента создаётся только при наличии группы крови. А, значит, нужно искать какой-то способ сначала эту группу крови получить, и только потом создавать карту. Программирование моделирует реальный процесс. В настоящей работе даже на языках с типами, конечно, без должного контроля можно написать что угодно. Нужна управленческая воля, компетентность руководства, понимание опасности техдолга, в идеале отдельные должности для архитекторов, опытные лиды и старшие разработчики. Но когда всё это есть, можно отсекать много проблем ещё на старте и проще погружать новичков. #dev

Hashtags

Резултати

Намерени 15 подобни публикации

Търсене: #uibug

当前筛选 #uibug清除筛选
YuKongA | Channel

@YuKongA13579 · Post #1263 · 19.02.2025 г., 07:34

但我依旧要再说一个这界面的 UI 问题,其他地方的 dropdown 展开时,后方条目是有选中效果(而你省电与电池特立独行) #Xiaomi#UIBUG

YuKongA | Channel

@YuKongA13579 · Post #1153 · 16.11.2024 г., 10:24

小米的软件开发到 Android 15 还不太不会做边到边 (edgeToEdge) 适配。 具体例子:日历应用的底栏,关了小白条高度都不会变🤣 以及小米的软件开发是真不知道你家这个跟 AOSP 行为不一致的小白条有多难用么🥵 前排提示:这是不用小白条才有的问题。 #Xiaomi#UIBUG

YuKongA | Channel

@YuKongA13579 · Post #1500 · 02.09.2025 г., 12:31

Telegram 官方版本终于 target 35 了,所以在小米上喜提输入框上移的问题🤣 * 仅安卓 15 ,安卓 16 小米修好了。 * 仅使用默认字体 MiSans 时会触发。 相关参考: 1、https://t.me/YuKongA13579/1145 2、https://t.me/YuKongA13579/1488 #HyperOS#UIBUG

YuKongA | Channel

@YuKongA13579 · Post #1267 · 22.02.2025 г., 02:31

给大家看看 ColorOS 引以为傲的桌面动画,说实话这比后做的 HyperOS 差远了... 不管是打断还是并行。 后台是完全不支持连续操作(与堆叠无关,平铺也是这样的,15.6.7 版本修了一部分),我就切个后台必须等它播放完动画,不然它就直接跳过了。并行动画也是前一个图标不会回到模糊状态和正确位置,只是自顾自走。 以及,ColorOS 的应用开关动画基本上是不能甩的,几乎完全是固定路径。 #ColorOS#UIBUG

12
ПредишнаСтр. 1 от 2Следваща