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

Резултати

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

Търсене: #chinaunicom

当前筛选 #chinaunicom清除筛选
不求甚解

@Fakeye · Post #12 · 04.11.2019 г., 01:54

#ChinaUnicom 联通用户在水深火热中啊。作为一个 7 年联通老粉,当年为了支持联通 FDD LTE 而抛弃了移动,可现在联通依旧信号覆盖弱,在目前阶段还涉嫌 4G 降速,让老用户有苦难言。 就拿前阶段的真实事情来说吧。公司园区联通信号堪忧,只要一进入电梯或者地下车库就没信号了,看到 Twitter 上有朋友通过工信部投诉解决了小区信号覆盖的问题。索性我也试试,于是在今年 8 月 20 日左右去工信部网站填了表,2 天后接到联通工作人员打来的电话,告知我所投诉的地点目前其实已经在做基站覆盖的施工了,但是苦于硬件设备迟迟没有到货所以还没有完成施工,现场人员反馈 10 月底可以完工,该工作人员表示将会一直跟踪我的投诉直至施工完成。目前已经 11 月了,信号问题仍然没有解决,上周联通的工作人员又打来电话,说是设备到货太晚了,现场人员反馈需要11 月底才能完成部署,让我耐心等等,他会一直跟踪。 所以说,从目前阶段来看,联通的信号覆盖问题真的是令人头痛,投诉后依然不受重视,不知道都忙着部署 5G 去了还是有什么其他原因。我现在唯一希望的就是 11 月底携号转网服务正式施行,马上转走 👋。

Hashtags