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

Резултати

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

Търсене: #thoughtyi

当前筛选 #thoughtyi清除筛选

https://t.me/Ralphonograph 这个大佬的Channel对我影响很大,大到可以说是人生转折点的程度。我见过无数描绘计算机系学生的文章、博客、知乎回答等,但受篇幅限制都太简略了,像盲人摸象只摸到了一个耳朵或鼻子一样。 只有这个大佬发的内容是细致入微的,深入大佬所感兴趣的每一堂有意思的课,每一张ppt,每一个知识点,每一个实验,每一篇论文并配有个人感悟。随着学习进度经常更新。看这位大佬的Channel,感觉就像坐在大佬身边一起听课一样,我可以清晰的看到大佬在学习道路上走出的每一步,这种感觉是从来都没有的。我第一次看到了活灵活现的大佬。 我是从这里才知道名牌大学的计算机专业纯英文授课的比例如此之高。也第一次发现了计算机深入研究下去会有很多有趣的知识。高考前努力学习的动力之一就是希望能变成大佬的样子,或者至少能成为大佬的同学。 大佬没有提到自己的个人情况和私人生活,也没有开启评论区,想必是不想被打扰。既然这样,我们就不去打听、研究大佬在现实中究竟是谁了,让大佬安静一下吧。 以后如果有机会遇到这位大佬的话,一定要向大佬表达一下感激之情。我是从小看着你的Channel长大的。你是我在计算机方面的 第二个老师 。 生理的成长与学术上的成长是两条线。生理成熟度随时间正比例增长,学术成熟度则未必。生理上的成年人,在学术方面可能仍然是小孩子,要经过学习积累才能逐渐成为学术上的成年人。 所以,我会说我是从小看着你的Channel长大的。第一次看到时,我在计算机领域还是幼儿园水平的小孩子,而你已经是大人了。小朋友很久都没有弄清楚的事情,大人一句话也许就能讲明白,让孩子获得成长。能成为你1221 subscribers 之中的一员是我的荣幸。 #Comment#ComputerScience#Emotion#English#Feeling#Learning#Life#Original#Thoughtyi