2018-02-22 09:09:53 +03:00
|
|
|
// move_semantics2.rs
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
2023-09-04 15:20:37 +03:00
|
|
|
// Make the test pass by finding a way to keep both Vecs separate!
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
|
|
|
// Execute `rustlings hint move_semantics2` or use the `hint` watch subcommand
|
|
|
|
// for a hint.
|
2023-02-18 20:43:34 +03:00
|
|
|
|
2023-09-04 15:20:37 +03:00
|
|
|
#[test]
|
2018-11-09 22:31:14 +03:00
|
|
|
fn main() {
|
2023-09-04 15:20:37 +03:00
|
|
|
let vec0 = vec![22, 44, 66];
|
2015-09-23 05:20:04 +03:00
|
|
|
|
2024-01-31 23:59:06 +03:00
|
|
|
let vec1 = fill_vec(vec0.clone());
|
|
|
|
|
|
|
|
// When vec0 is passed to fill_vec, the function takes OWNERSHIP
|
|
|
|
// of the vector. It mutates the vector and passes ownershpip to vec1.
|
|
|
|
// Once a value has moved, we can no longer use it.
|
|
|
|
// this is why, we need to clone it so that we can use it again
|
|
|
|
|
|
|
|
// Using clone() makes an entire copy of the vector. DEEP COPY.
|
|
|
|
// It is also a separate object in memory.
|
|
|
|
// Changes to the original vector does not affect the cloned vector and vice versa
|
2015-09-23 05:20:04 +03:00
|
|
|
|
2023-09-04 15:20:37 +03:00
|
|
|
assert_eq!(vec0, vec![22, 44, 66]);
|
2024-01-31 23:59:06 +03:00
|
|
|
assert_eq!(vec1, vec![22, 44, 66, 88]);
|
2015-09-23 05:20:04 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
fn fill_vec(vec: Vec<i32>) -> Vec<i32> {
|
|
|
|
let mut vec = vec;
|
|
|
|
|
2023-09-04 15:20:37 +03:00
|
|
|
vec.push(88);
|
2015-09-23 05:20:04 +03:00
|
|
|
|
|
|
|
vec
|
|
|
|
}
|