
Pour cette nouvelle version, environ 40 fonctions et méthodes ont été rendues stables. Au nombre de celles-ci, l’on a par exemple la fonction relative_from permettant de retourner un chemin, qui a été dépréciée et renommée en strip_prefix. La méthode is_loopback(&self) retourne la valeur « vrai » si l’adresse à vérifier est une adresse Loop back selon le registre RFC 6890.
Par ailleurs, pour copier les données d’un slice (une vue dans une région de mémoire) afin de l’insérer dans un autre slice, il faut utiliser la méthode <[T]>::clone_from_slice(). En ce qui concerne CString, plusieurs améliorations ont été également apportées afin d’utiliser du code C à partir de l’interface FFI.
Mais au-delà de ces éléments, le point le plus important pour ce qui est de la stabilisation des fonctions et méthodes, c’est le support des algorithmes de hachage personnalisé contenu dans le type HashMap<K, V> de la bibliothèque standard de Rust. Il faut rappeler qu’auparavant tous les dictionnaires de hachage utilisaient l’algorithme de hachage SipHash pour assurer la protection par défaut contre les attaques par déni de service. Toutefois, cet algorithme présente des inconvénients en matière de performance lorsqu’il s’agit de hacher de petites clés.
Pour résoudre le problème, vous pouvez basculer sur l’algorithme de hachage FNV qui montre des performances meilleures en matière de hachage de ce type de clés. En outre, il est bon de savoir que ce gain de performance se fait au détriment de la protection contre les attaques par déni de service. Si cela ne vous pose aucun problème, vous pouvez alors adopter ce dernier, suggère l’équipe de Rust.
En dehors du point d’honneur qui a été mis sur les fonctions et les méthodes, l’on a quelques améliorations au niveau des fonctionnalités de Cargo, le gestionnaire de package. Ainsi, il a été introduit des ajouts permettant d’avertir le gestionnaire lorsque des changements surviennent au niveau des dépendances. Cela a l’avantage de déclencher une réexécution des scripts de construction seulement lorsque des changements ont eu lieu dans les dépôts des dépendances et non de manière aléatoire.
À ces différents changements, il faut ajouter la modification de la sous-commande rustc afin de pouvoir compiler les objets ciblés dans plusieurs profils disponibles (dev, brench, test). À côté de ces éléments, il faut souligner que la collection BTreeMap a été réécrite afin d’utiliser moins de mémoire et améliorer les performances des insertions et des itérations.
De nombreuses autres améliorations ont été implémentées dans cette nouvelle version et environ 1300 correctifs ont été intégrés.
Source : Blog Rust
Et vous ?

Voir aussi
