Улучшения в 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.


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

19521Банковский троян VENON на Rust атакует Бразилию с помощью девяти техник обхода защиты 19520Бонобо агрессивны не меньше шимпанзе, но всё решают самки 19519Почему 600-килограммовый зонд NASA падает на Землю из-за солнечной активности? 19518«Липовый календарь»: как расписание превращает работников в расходный материал 19517Вредоносные Rust-пакеты и ИИ-бот крадут секреты разработчиков через CI/CD-пайплайны 19516Как хакеры за 72 часа превратили npm-пакет в ключ от целого облака AWS 19515Как WebDAV-диск и поддельная капча помогают обойти антивирус? 19514Могут ли простые числа скрываться внутри чёрных дыр? 19513Метеорит пробил крышу дома в Германии — откуда взялся огненный шар над Европой? 19512Уязвимости LeakyLooker в Google Looker Studio открывали доступ к чужим базам данных 19511Почему тысячи серверов оказываются открытой дверью для хакеров, хотя могли бы ею не быть? 19510Как исследователи за четыре минуты заставили ИИ-браузер Perplexity Comet попасться на... 19509Может ли женщина без влагалища и шейки матки зачать ребёнка естественным путём? 19508Зачем учёные из Вены создали QR-код, который невозможно увидеть без электронного... 19507Девять уязвимостей CrackArmor позволяют получить root-доступ через модуль безопасности...
Ссылка