Rouille - Emprunt
Il est très peu pratique de transmettre la propriété d'une variable à une autre fonction, puis de restituer la propriété. Rust prend en charge un concept, l'emprunt, dans lequel la propriété d'une valeur est transférée temporairement à une entité, puis renvoyée à l'entité propriétaire d'origine.
Considérez ce qui suit -
fn main(){
// a list of nos
let v = vec![10,20,30];
print_vector(v);
println!("{}",v[0]); // this line gives error
}
fn print_vector(x:Vec<i32>){
println!("Inside print_vector function {:?}",x);
}
La fonction principale invoque une fonction print_vector () . Un vecteur est passé en paramètre à cette fonction. La propriété du vecteur est également transmise à la fonction print_vector () à partir de main () . Le code ci-dessus entraînera une erreur comme indiqué ci-dessous lorsque la fonction main () essaiera d'accéder au vecteur v .
| print_vector(v);
| - value moved here
| println!("{}",v[0]);
| ^ value used here after move
En effet, une variable ou une valeur ne peut plus être utilisée par la fonction qui la possédait à l'origine une fois que la propriété est transférée à une autre fonction.
Qu'est-ce que l'emprunt?
Lorsqu'une fonction transfère temporairement son contrôle sur une variable / valeur à une autre fonction, pendant un certain temps, elle est appelée emprunt. Ceci est réalisé en passant une référence à la variable(& var_name)plutôt que de passer la variable / valeur elle-même à la fonction. La propriété de la variable / valeur est transférée au propriétaire d'origine de la variable une fois que la fonction à laquelle le contrôle a été passé a terminé l'exécution.
fn main(){
// a list of nos
let v = vec![10,20,30];
print_vector(&v); // passing reference
println!("Printing the value from main() v[0]={}",v[0]);
}
fn print_vector(x:&Vec<i32>){
println!("Inside print_vector function {:?}",x);
}
Production
Inside print_vector function [10, 20, 30]
Printing the value from main() v[0] = 10
Références mutables
Une fonction peut modifier une ressource empruntée en utilisant une référence mutable à une telle ressource. Une référence mutable est précédée du préfixe&mut. Les références mutables ne peuvent fonctionner que sur des variables mutables.
Illustration: Mutation d'une référence entière
fn add_one(e: &mut i32) {
*e+= 1;
}
fn main() {
let mut i = 3;
add_one(&mut i);
println!("{}", i);
}
La fonction main () déclare une variable entière mutable i et passe une référence mutable de i auadd_one(). La fonction add_one () incrémente la valeur de la variable i de un.
Illustration: muter une référence de chaîne
fn main() {
let mut name:String = String::from("TutorialsPoint");
display(&mut name);
//pass a mutable reference of name
println!("The value of name after modification is:{}",name);
}
fn display(param_name:&mut String){
println!("param_name value is :{}",param_name);
param_name.push_str(" Rocks");
//Modify the actual string,name
}
La fonction main () transmet une référence mutable du nom de la variable à la fonction display () . La fonction d'affichage ajoute une chaîne supplémentaire à la variable de nom d' origine .
Production
param_name value is :TutorialsPoint
The value of name after modification is:TutorialsPoint Rocks