1
0
mirror of https://github.com/google/comprehensive-rust.git synced 2025-04-05 10:05:39 +02:00

Add “More to Explore” sections (#1369)

From a discussion in #1313.
This commit is contained in:
Martin Geisler 2023-10-16 15:42:07 +02:00 committed by GitHub
parent 29c121cb54
commit f94daaea73
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 39 additions and 14 deletions

View File

@ -65,6 +65,24 @@ collapsed or removed entirely from the slide.
course, instructors will only have time to glance at the notes so it is not
useful to include full paragraphs which the instructor should read out loud.
### More to Explore
Move extended explanations in the notes to a "More to Explore" section:
```markdown
<details>
...
## More to Explore
...
</details>
```
The material there is outside the scope of the regular class.
## Translations
This section is about what you write in the translation. We describe

View File

@ -58,6 +58,10 @@ Key Points:
* `dbg_size!(&i32)`: size 8 bytes, align: 8 bytes (on a 64-bit machine),
* `dbg_size!(Option<&i32>)`: size 8 bytes, align: 8 bytes (null pointer optimization, see below).
## More to Explore
Rust has several optimizations it can employ to make enums take up less space.
* Niche optimization: Rust will merge unused bit patterns for the enum
discriminant.

View File

@ -29,22 +29,25 @@ fn main() {
* If students ask about it, you can mention that the underlying memory is heap allocated using the [System Allocator] and custom allocators can be implemented using the [Allocator API]
* We can inspect the memory layout with `unsafe` code. However, you should point out that this is rightfully unsafe!
## More to Explore
```rust,editable
fn main() {
let mut s1 = String::from("Hello");
s1.push(' ');
s1.push_str("world");
// DON'T DO THIS AT HOME! For educational purposes only.
// String provides no guarantees about its layout, so this could lead to
// undefined behavior.
unsafe {
let (ptr, capacity, len): (usize, usize, usize) = std::mem::transmute(s1);
println!("ptr = {ptr:#x}, len = {len}, capacity = {capacity}");
}
We can inspect the memory layout with `unsafe` Rust. However, you should point
out that this is rightfully unsafe!
```rust,editable
fn main() {
let mut s1 = String::from("Hello");
s1.push(' ');
s1.push_str("world");
// DON'T DO THIS AT HOME! For educational purposes only.
// String provides no guarantees about its layout, so this could lead to
// undefined behavior.
unsafe {
let (ptr, capacity, len): (usize, usize, usize) = std::mem::transmute(s1);
println!("ptr = {ptr:#x}, len = {len}, capacity = {capacity}");
}
```
}
```
</details>