2022-03-29 16:02:35 +03:00
|
|
|
// move_semantics6.rs
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
2022-07-12 16:43:26 +03:00
|
|
|
// You can't change anything except adding or removing references.
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
|
|
|
// Execute `rustlings hint move_semantics6` or use the `hint` watch subcommand
|
|
|
|
// for a hint.
|
2022-03-29 16:02:35 +03:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let data = "Rust is great!".to_string();
|
|
|
|
|
2024-01-31 23:59:06 +03:00
|
|
|
// get_char is taking ownership of the data
|
|
|
|
// a reference is like a pointer.
|
|
|
|
// it's an address to the data that we want to access.
|
|
|
|
// the difference though is that a reference is guaranteed to point to a valid value
|
|
|
|
// of a particular type for the life of that
|
|
|
|
get_char(&data);
|
2022-03-29 16:02:35 +03:00
|
|
|
|
2024-01-31 23:59:06 +03:00
|
|
|
string_uppercase(data);
|
2022-03-29 16:02:35 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Should not take ownership
|
2024-01-31 23:59:06 +03:00
|
|
|
|
|
|
|
//In this case, the function is taking a reference to avoid data copying
|
|
|
|
// The original string is needed after the function call.
|
|
|
|
// get_char does not modify the data, only reads it so we can just pass the reference.
|
|
|
|
|
|
|
|
|
|
|
|
fn get_char(data: &String) -> char {
|
2022-03-29 16:02:35 +03:00
|
|
|
data.chars().last().unwrap()
|
2024-01-31 23:59:06 +03:00
|
|
|
// This function is getting the last character of the string reference
|
|
|
|
// in this test case, i would be '!'
|
|
|
|
// println!('{}'. char); would print '!'
|
2022-03-29 16:02:35 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Should take ownership
|
2024-01-31 23:59:06 +03:00
|
|
|
// because it is modifying the value of data
|
|
|
|
// the mut in the parameters allows it to reassign a value to the 'data'
|
|
|
|
fn string_uppercase(mut data: String) {
|
|
|
|
data = data.to_uppercase();
|
2022-03-29 16:02:35 +03:00
|
|
|
|
|
|
|
println!("{}", data);
|
|
|
|
}
|