From 59d63a6e892fa91a1499f31853d239fb02cf580c Mon Sep 17 00:00:00 2001 From: Nicole L Date: Fri, 19 Apr 2024 07:18:31 -0700 Subject: [PATCH] Simplify the example code for `Clone` (#2001) The previous example code for the `Clone` slide was a bit too complex in a way that obscured the fundamental point. I've replaced it with the `say_hello` example from the previous slide, but updated to demonstrate how cloning can address the borrow checker error. I also added a speaker note to mention that `Clone` performs a deep copy, which might be different from what students are used to if they come from a language like Python that does shallow copies by default. --- src/memory-management/clone.md | 29 ++++++++++++++++------------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/src/memory-management/clone.md b/src/memory-management/clone.md index a10da95af0a..897c5b80f93 100644 --- a/src/memory-management/clone.md +++ b/src/memory-management/clone.md @@ -8,26 +8,29 @@ Sometimes you _want_ to make a copy of a value. The `Clone` trait accomplishes this. ```rust,editable -#[derive(Default)] -struct Backends { - hostnames: Vec, - weights: Vec, +fn say_hello(name: String) { + println!("Hello {name}") } -impl Backends { - fn set_hostnames(&mut self, hostnames: &Vec) { - self.hostnames = hostnames.clone(); - self.weights = hostnames.iter().map(|_| 1.0).collect(); - } +fn main() { + let name = String::from("Alice"); + say_hello(name.clone()); + say_hello(name); } ```
-The idea of `Clone` is to make it easy to spot where heap allocations are -occurring. Look for `.clone()` and a few others like `Vec::new` or `Box::new`. +- The idea of `Clone` is to make it easy to spot where heap allocations are + occurring. Look for `.clone()` and a few others like `Vec::new` or `Box::new`. -It's common to "clone your way out" of problems with the borrow checker, and -return later to try to optimize those clones away. +- It's common to "clone your way out" of problems with the borrow checker, and + return later to try to optimize those clones away. + +- `clone` generally performs a deep copy of the value, meaning that if you e.g. + clone an array, all of the elements of the array are cloned as well. + +- The behavior for `clone` is user-defined, so it can perform custom cloning + logic if needed.