Улучшения в Rust 1.84: безопасность, производительность и новые возможности

Rust 1.84 вносит значительные улучшения, направленные на повышение надежности и эффективности разработки. Новый обработчик типажей в компиляторе обеспечивает более строгую проверку совместимости типов, устраняя потенциальные конфликты и повышая предсказуемость поведения программ. Cargo, менеджер пакетов Rust, теперь автоматически учитывает минимально поддерживаемые версии компилятора для зависимостей, упрощая управление проектами, ориентированными на совместимость со старыми версиями Rust.
Улучшения в Rust 1.84: безопасность, производительность и новые возможности
Изображение носит иллюстративный характер

Введена новая система Strict Provenance для работы с указателями, обеспечивающая безопасное преобразование указателей в целые числа и обратно, сохраняя информацию о происхождении, что критически важно для низкоуровневых операций и управления памятью. Стабилизированы новые API, включая функции для работы с IP-адресами, указателями и целочисленными значениями, расширяя возможности разработчиков при работе с сетевыми технологиями и низкоуровневыми структурами. Кроме того, const признак применен к ряду функций, в том числе для работы с атомарными типами, что позволяет использовать их в константных контекстах.

В части производительности стабилизирована поддержка inline-ассемблерных вставок для s390x и Arm64EC архитектур, предоставляя разработчикам возможность оптимизировать код, который требует прямого доступа к процессору. Существенно расширены возможности WebAssembly, благодаря стабилизации таких функций как Multivalue, Reference-types и Tail-call, которые позволяют создавать более сложные и производительные веб-приложения. Вдобавок, второй уровень поддержки wasm32v1-none гарантирует стабильность сборки программ Rust для этой минималистичной платформы.

Развитие экосистемы Rust также не стоит на месте. Операционная система Tock на Rust позволяет запускать доверенные приложения на микроконтроллерах, обеспечивая изоляцию между уровнями приложения, ядра и драйверов. Проект VEKOS, ядро операционной системы с акцентом на верификацию компонентов, использует криптографические подтверждения для каждой операции с файловой системой и памятью. И, наконец, Mini-C, подмножество языка C, разрабатывается для автоматической трансляции C программ в Rust, упрощая миграцию устаревшего кода в безопасный Rust без блоков unsafe.


Новое на сайте

19791Гражданская война шимпанзе в Уганде 19790Кибершпионы UAT-10362 охотятся на тайваньские нко с помощью малвари LucidRook 19789Телескоп Джеймса Уэбба обнаружил галактику-«ската» в скоплении MACS J1149 19788Комета MAPS сгорела в солнечной короне и вылетела облаком обломков 19787Кто стоит за кибератаками на журналистов ближнего Востока и зачем Индии понадобилась... 19786Теневой ИИ в компаниях: угроза, которую не видят безопасники 19785Почему NASA спокойно относится к проблеме с теплозащитным экраном Artemis II? 19784Шифрование видео, которое не сломает даже квантовый компьютер 19783Западу США грозит аномально опасный сезон пожаров 19782Белок, который не должен убивать: как одна гипотеза перевернула биологию 19781Серебряная монета XVI века указала на затерянную испанскую колонию у магелланова пролива 19780Что за загадочные клетки появляются в организме женщины только во время беременности? 19779Кератин как тормоз воспаления: неожиданная роль знакомого белка 19778Ботнет Chaos перенацелился на облака и обзавёлся SOCKS-прокси 19777Когда комета PanSTARRS станет видна невооружённым глазом?
Ссылка