Rust - Meminjam
Sangat merepotkan untuk meneruskan kepemilikan variabel ke fungsi lain dan kemudian mengembalikan kepemilikan. Rust mendukung konsep, meminjam, di mana kepemilikan suatu nilai ditransfer sementara ke entitas dan kemudian dikembalikan ke entitas pemilik asli.
Pertimbangkan hal berikut -
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);
}
Fungsi utama memanggil fungsi print_vector () . Vektor dilewatkan sebagai parameter untuk fungsi ini. Kepemilikan vektor juga diteruskan ke fungsi print_vector () dari main () . Kode di atas akan menghasilkan kesalahan seperti yang ditunjukkan di bawah ini ketika fungsi main () mencoba mengakses vektor v .
| print_vector(v);
| - value moved here
| println!("{}",v[0]);
| ^ value used here after move
Ini karena variabel atau nilai tidak dapat lagi digunakan oleh fungsi yang semula dimiliki setelah kepemilikan dipindahkan ke fungsi lain.
Apa itu Meminjam?
Ketika suatu fungsi mentransfer kontrolnya atas variabel / nilai ke fungsi lain untuk sementara, untuk sementara, itu disebut peminjaman. Ini dicapai dengan meneruskan referensi ke variabel(& var_name)daripada meneruskan variabel / nilai itu sendiri ke fungsi tersebut. Kepemilikan variabel / nilai ditransfer ke pemilik asli variabel setelah fungsi yang diberikan kontrol menyelesaikan eksekusi.
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);
}
Keluaran
Inside print_vector function [10, 20, 30]
Printing the value from main() v[0] = 10
Referensi yang Dapat Diubah
Sebuah fungsi bisa memodifikasi sumber daya yang dipinjam dengan menggunakan referensi yang bisa berubah ke sumber daya tersebut. Referensi yang bisa berubah diawali dengan&mut. Referensi yang dapat diubah hanya dapat beroperasi pada variabel yang dapat diubah.
Ilustrasi: Mutasi referensi integer
fn add_one(e: &mut i32) {
*e+= 1;
}
fn main() {
let mut i = 3;
add_one(&mut i);
println!("{}", i);
}
Fungsi main () mendeklarasikan variabel integer yang bisa berubah i dan meneruskan referensi yang bisa berubah dari i keadd_one(). Add_one () menambah nilai variabel i dengan satu.
Ilustrasi: Mutasi referensi string
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
}
Fungsi main () meneruskan referensi yang bisa berubah dari nama variabel ke fungsi display () . Fungsi tampilan menambahkan string tambahan ke variabel nama asli .
Keluaran
param_name value is :TutorialsPoint
The value of name after modification is:TutorialsPoint Rocks