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

Резултати

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

Търсене: #containership

当前筛选 #containership清除筛选

🚢HJ Shipbuilding & Construction получила заказ на два контейнеровоза по 10 100 TEU. Южнокорейская верфь HJ Shipbuilding & Construction (HJSC) подписала контракт с неназванным европейским судовладельцем на строительство двух контейнеровозов вместимостью по 10 100 TEU. Общая стоимость сделки — KRW 353,2 млрд ($264,9 млн), с опционом заказа ещё двух судов аналогичной спецификации. Это первый случай, когда на верфи Yeongdo будет построено судно свыше 10 000 TEU вместимости. Новострои получат оптимизированный корпус для повышения топливной эффективности, а также система скруббера в соответствии с требованиями IMO. Ранее HJSC передала HMM контейнеровоз, работающий на метаноле вместимостью 9 000 TEU. Контракт подтверждает стратегию верфи по усилению позиций в сегменте средне- и крупнотоннажных контейнеровозов и отражает постепенное возвращение заказов на корейские мощности на фоне конкуренции с китайскими верфями. 📌HJ Shipbuilding & Construction ведёт историю с 1937 года (ранее Hanjin Heavy Industries). Компания публичная; контрольный пакет принадлежит корейской группе Dongbu Corporation через аффилированные структуры. #shipbuilding#containership#SouthKorea#newbuilding#maritime

🚢Tsuneishi передала Maersk двухтопливный контейнеровоз, вместимостью 5 900 TEU. Японская верфь Tsuneishi Shipbuilding передала контейнеровоз вместимостью 5 900 TEU с двухтопливной метанольной силовой установкой, построенный на китайской площадке Tsuneishi Group (Zhoushan) Shipbuilding Inc. (TZS). Судно выйдет в тайм-чартер с A.P. Moller – Maersk. По заявлению верфи, поставка знаменует переход к серийному строительству судов, способных работать на альтернативных видах топлива на зарубежных производственных базах. Ранее, в 2025 году, Tsuneishi передала балкер на метанольном топливе типоразмера Ultramax в Японии и первый в мире балкер на метаноле крупнотоннажного типоразмера Kamsarmax, построенный на филиппинской верфи группы. Сделка отражает устойчивый спрос крупных линейных операторов на метанол как переходное топливо и расширение глобальной производственной модели японских судостроителей. 📌Tsuneishi Shipbuilding основана в 1917 году в Японии и входит в частную Tsuneishi Group. Исторически бизнес был основан в 1903 году как судоремонтная мастерская в районе Томоноура (префектура Хиросима) и оставался семейной компанией. Со временем структура была реорганизована в холдинговую модель Tsuneishi Group, однако контроль по-прежнему сосредоточен у семьи Камитани (神谷家 / Kamitani) через частные холдинговые структуры. #containership#methanol#dualfuel#shipbuilding#Maersk

🚢Датские исследователи ускорили обнаружение пожаров на контейнеровозах. Серия инцидентов с пожарами на контейнерных судах стимулировала поиск более быстрых методов раннего выявления возгораний. Датские исследователи провели испытания на борту мега-контейнеровоза "Mumbai Maersk" (20 500 TEU, 2018 г.п.), чтобы сравнить эффективность тепловых сенсоров и традиционных дымовых детекторов. В рамках тестов использовались два типа тепловых датчиков, встроенных в поручни. По результатам экспериментов, такие сенсоры способны обнаруживать возгорание на шесть минут быстрее, чем стандартные дымовые системы. Для крупных контейнеровозов это может означать критически важное время для локализации очага и предотвращения масштабного ущерба. Исследование подчёркивает потенциал модернизации противопожарной инфраструктуры флота в условиях роста объёмов перевозок и усложнения грузовых профилей. 📌 Судно "Mumbai Maersk" эксплуатируется группой A.P. Moller – Maersk, основанной в 1904 году. Контрольный пакет принадлежит датскому холдингу A.P. Moller Holding, находящемуся под управлением семьи Мёллер. #containership#firesafety#maritimetech#Maersk#shipping