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 подобни публикации

Търсене: #onlyoffice

当前筛选 #onlyoffice清除筛选
科技&趣闻&杂记

@kejiqu · Post #3581 · 20.06.2025 г., 02:47

开源办公套件 ONLYOFFICE 9.0 发布:优化界面、整合 AI 技能、支持 Markdown ONLYOFFICE 9.0版本已发布,该开源办公套件在界面优化基础上,新增了对Visio、Markdown等格式文件的直接查看支持,并引入AI技术以提升效率。新版本优化了PDF、Document、Spreadsheet和Presentation编辑器的界面布局,并提供“现代浅色”和“现代深色”主题选项。新增的“图表查看器”功能允许用户直接打开Visio(.vsdx)和OpenDocument Graphic(.odg)等格式文件,同时增加了对Markdown(.md)和Excel二进制工作簿(.xlsb)等格式的支持。在AI方面,ONLYOFFICE 9.0实现了宏自动化,能够通过AI转换宏或VBA脚本,并快速识别扫描PDF文档中的文字。此外,PDF编辑器新增实时协作表单功能,Spreadsheet支持从外部数据源直接导入信息。IT之家 | ONLYOFFICE 🏷#ONLYOFFICE#AI#Visio 📢频道👥群组📝投稿

科技&趣闻&杂记

@kejiqu · Post #4327 · 06.04.2026 г., 01:05

欧洲企业联合推出开源办公套件 Euro-Office,对标微软谷歌办公平台 Nextcloud、Ionos及其他欧洲企业与社区组织组成的联盟于近期在德国柏林推出Euro-Office,该项目为OnlyOffice的开源分支版本,旨在替代微软Office 365和谷歌文档等办公平台。Euro-Office首个稳定版计划于今年夏季发布,预览版本已在GitHub上线。该应用套件兼容微软Office标准格式文件(DOCX、PPTX、XLSX)及LibreOffice/OpenOffice的开放文档格式(ODS、ODT、ODP),并基于网页端开发,可集成至文件共享平台等。项目团队选择基于OnlyOffice进行分支开发,原因是后者代码合并请求审核不及时且构建说明不可靠,同时提及与OnlyOffice俄罗斯总部合作的信任问题。据《How-To Geek》报道,Euro-Office是欧洲科技企业打造开源工具替代谷歌文档与微软365的多款项目之一。OnlyOffice团队声明Euro-Office未经许可使用代码库并违反GNU Affero通用公共许可证第3版(AGPL v3)的多项条款。IT之家 🏷#Euro#Office#OnlyOffice#开源 📢频道👥群组📝投稿

AIGC

@aigcrubbish · Post #315 · 15.04.2026 г., 19:06

FSF clarifies its stance on AGPLv3 additional terms 自由软件基金会(FSF)近日就AGPLv3许可证的附加条款问题发表了官方立场声明。此前,OnlyOffice首席执行官Lev Bannov指控其软件的分支项目Euro-Office违反了GNU Affero通用公共许可证第三版(AGPLv3)。FSF的Krzysztof Siewicz在文章中明确指出,OnlyOffice在其软件许可中添加了与AGPLv3不兼容的额外限制条款。 FSF认为,这些附加限制违反了AGPLv3许可证的精神,并且接收代码的用户有权移除这些限制。基金会敦促OnlyOffice澄清其许可状态,明确其软件基于AGPLv3授权,并确保未来版本中不再包含任何额外限制。FSF强调,在GNU通用公共许可证家族的任何版本上附加限制性条款,会造成用户混淆,不符合自由软件的原则。 原文链接:https://lwn.net/Articles/1067771/ #开源许可#AGPLv3#自由软件基金会#OnlyOffice #AIGC Read more