@Ptfxq · Post #227 · 11.07.2021 г., 12:19
#GGn 官方邀请入驻 #PterClub
TGINSIGHT SIMILAR POSTS
Изходен канал @clockstackwheels · Post #721 · 26.12
Почему я люблю языки с сильной системой типов, проверяемой статическим анализом кода — хорошо написанная программа является своей собственной спецификацией и позволяет выражать через язык программирования законы существования предметной области. Когда-то давно я писал на ActionScript. Там была система типов, но вот десериализация JSON'ов по-умолчанию была в какой-то общий Object, к полям которого нужно было обращаться ["по_строковому_имени"]. В один момент мне потребовалось написать что-то на C#, который я совсем не знал, я стал гуглить, как десериализовать JSON, и с удивлением обнаружил кучу советов заранее объявить класс со всеми нужными полями и десериализовать в него. "Какой ужас!", — подумал я тогда, — "Это же дико неудобно! А если я не знаю полей JSON? А если их много? Отвратительный язык!" Теперь то я прекрасно понимаю, что JSON это контракт, и что правильная десериализация только такая и должна быть, и что в хорошем API в одном поле никогда не бывает данных принципиально разных типов, и так далее. Нет, если вы набиваете вечерами пет-проект или сидите бессонную ночь на хакатоне, нет ничего плохого в том, чтобы взять простой язык с динамическими типами вроде JavaScript или Python, не требующий описывать данные. Но вот в энтерпрайзе, особенно когда над одним проектом работает много людей (а бывает это очень часто) — хорошее использование системы типов убережёт разработчиков от огромного количества ошибок, будет бить их по рукам, когда они пытаются сделать что-то не то, и будет подсказывать, когда они не уверены в чём-то. С помощью статической типизации можно на уровне кода обозначить правила, по которым ведёт себя предметная область вашей программы в реальном мире. Разработчику не только будет сложно их нарушить, но он ещё и станет узнавать какие-то вещи, которые мог не знать раньше. Например, если мы делаем медицинскую CRM, и больница заводит новых пациентов только тогда, когда знает их группу крови, мы можем объявить тип "Пациент" (или, если точнее, "Карта пациента") и запретить создавать экземпляры этого типа, не передав в конструктор группу крови (которая, в свою очередь, тоже является типом, вероятнее всего ValueObject'ом). Если новый программист пришёл в проект, он, во-первых, не сможет записать в БД некорректную карту пациента. Понятно, мы не учитываем случаи, когда новый программист переделывает модели предметной области — это будет хорошо видно на кодревью. А, во-вторых, даже если ему никто не сказал, что пациенты должны быть с группой крови, он узнает это из кода. И уже будет понимать, что в тех процессах реальной жизни, которые он описывает кодом, карта пациента создаётся только при наличии группы крови. А, значит, нужно искать какой-то способ сначала эту группу крови получить, и только потом создавать карту. Программирование моделирует реальный процесс. В настоящей работе даже на языках с типами, конечно, без должного контроля можно написать что угодно. Нужна управленческая воля, компетентность руководства, понимание опасности техдолга, в идеале отдельные должности для архитекторов, опытные лиды и старшие разработчики. Но когда всё это есть, можно отсекать много проблем ещё на старте и проще погружать новичков. #dev
Hashtags
Търсене: #pterclub
@Ptfxq · Post #227 · 11.07.2021 г., 12:19
#GGn 官方邀请入驻 #PterClub
@Ptfxq · Post #709 · 19.08.2024 г., 07:04
#PTerClub#猫站#站免 开始:2024-08-19 13:06 (UTC+8) 结束:2024-08-20 13:06 (UTC+8)
@Ptfxq · Post #679 · 30.06.2024 г., 16:30
#PTerClub#猫站#站免 站免一天。
@Ptfxq · Post #343 · 10.09.2022 г., 00:01
#PTerClub#猫站#站免 节日快乐!全站免费已开启 开始时间:2022-09-09 23:40:00 UTC+8 结束时间:2022-09-13 00:00:00 UTC+8
@Ptfxq · Post #886 · 01.05.2025 г., 06:06
#PTerClub#猫站#站点免费 各位猫友五一劳动节快乐,站免三天到5月3日23点59分,外加五一劳动节徽章限时换购。
@Ptfxq · Post #838 · 17.01.2025 г., 08:33
#PTerClub#猫站#站点免费 全站 [Free] 生效中! 开始:2025-01-17 16:12 (UTC+8) 结束:2025-01-18 16:12 (UTC+8)
@Ptfxq · Post #827 · 29.12.2024 г., 09:08
#PTerClub#猫站#站点免费 提前祝大家新年快乐,猫站自 2024-12-30 0:00 至 2025-01-01 23:59 期间站免!
@Ptfxq · Post #362 · 30.09.2022 г., 13:07
#PTerClub#猫站#综合公告 1. 10月1日至10月3日期间站免。 2. 站点扩容,邀请等级不变。 3. 国庆徽章将会在近期推出。 祝各位猫友国庆快乐!
@Ptfxq · Post #623 · 22.03.2024 г., 16:30
#PTerClub#猫站#站点维护 小编:不要慌,是技术性调整 已恢复
@Ptfxq · Post #972 · 31.12.2025 г., 11:45
#PTerClub#猫站#站点免费#开放邀请 各位猫友,大家好! 辞旧迎新之际,伴随着新一年的到来,我们很高兴地向大家宣布一个好消息——猫站正式迎来七周年! 🎉 在过去的一年中,猫站先后完成了 Tracker 升级 与 域名更换。针对长期以来大家关心的人数上限问题,将会得到解决,自即日起,计划将站点容量扩容 3000 人数上限。受限于邮件服务容量,实际操作中将采取每日增加 200 人上限的方式,直至总人数上限达到 17000 人。 为庆祝猫站成立七周年,并与大家共度元旦佳节,我们特别准备了以下活动: 🎁 七周年庆活动 1. 站免(Freeleech) ⏰ 时间:2026-01-01 00:00 – 2026-01-03 23:59 UTC+8 🎉 全站 Free 三天 Site-wide freeleech is enabled from 01/01/2026 to 01/03/2026 UTC+8. 此外,关于邀请发放,请各位猫友务必注意: 邀请严禁滥发 严禁任何形式的交易邀请、马甲号、共享账号等行为 违规行为将直接影响您的账号安全,并可能波及您本人及所有下家的账号与邀请权限 请大家珍惜来之不易的邀请资格,共同维护良好的站点环境。 最后, 猫站管理组祝各位猫友元旦快乐,新年顺遂! 猫站管理组 敬上
@Ptfxq · Post #954 · 15.11.2025 г., 12:02
#PTerClub#猫站#关闭邀请 2025.11.15 - 邀请系统暂时关闭。 近期调查发现,相当部分用户通过不正当发放邀请,包括但不限于使用脚本、共享账号等手段。这些行为已严重偏离本站邀请系统的初衷。邀请系统设立的本意,从未将邀请权限视为某种“特权”或“权贵”专属,而是让每位用户能够邀请自己认为合适、值得信任的人进站,共同传递共享与互助的精神。 然而,当前系统已被部分用户滥用。他们通过组建小圈子互相“互送猫粮”以规避邀请冷却时间,或使用脚本、共享账号抢占邀请名额,使邀请权事实上被少数人垄断。更令人担忧的是,部分邀请的发放标准已从“能不能对社区有贡献”变成了“圈内关系好不好”、“是不是自己人”,甚至出现隐形的“邀请交换”。这种现象必然导致邀请质量下降与滥发问题的加剧。 另一方面,这些问题的根源也与站点“扩容”进度密切相关。此前在广大猫友的贡献下,peer 数量已达到约 260 万,服务器负载难以支撑进一步增长(“抢坑”现象即是在全员拥有邀请权限的情况下出现的)。因此,站点必须对 tracker 进行升级改造,以提升系统承载能力。上述不良现象的出现,与 tracker 升级进度缓慢也有客观联系。对此,我们向未参与任何违规行为却受到影响的用户致以歉意。 目前,tracker 改造已进入收尾阶段。预计在扩容完成后,邀请系统将重新开放。在此期间,我们将倒查近期的邀请记录,对违规发放邀请的行为坚决处理。如果你曾使用不正当方式发放邀请,建议尽快私信管理组信箱主动说明情况,以争取从轻处理。
@Ptfxq · Post #690 · 29.07.2024 г., 14:54
#KEEPFRDS#FRDS#PTerCLub#猫站 FRDS 在 猫站 开设了官邀