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

37 lines
1.1 KiB
Markdown
Raw Normal View History

---
minutes: 5
---
2022-12-21 16:36:30 +01:00
# Unsafe Rust
The Rust language has two parts:
* **Safe Rust:** memory safe, no undefined behavior possible.
* **Unsafe Rust:** can trigger undefined behavior if preconditions are violated.
We saw mostly safe Rust in this course, but it's important to know
what Unsafe Rust is.
2022-12-21 16:36:30 +01:00
Unsafe code is usually small and isolated, and its correctness should be carefully
documented. It is usually wrapped in a safe abstraction layer.
2022-12-21 16:36:30 +01:00
Unsafe Rust gives you access to five new capabilities:
* Dereference raw pointers.
* Access or modify mutable static variables.
* Access `union` fields.
* Call `unsafe` functions, including `extern` functions.
2022-12-21 16:36:30 +01:00
* Implement `unsafe` traits.
We will briefly cover unsafe capabilities next. For full details, please see
[Chapter 19.1 in the Rust Book](https://doc.rust-lang.org/book/ch19-01-unsafe-rust.html)
and the [Rustonomicon](https://doc.rust-lang.org/nomicon/).
<details>
Unsafe Rust does not mean the code is incorrect. It means that developers have
turned off some compiler safety features and have to write correct code by
themselves. It means the compiler no longer enforces Rust's memory-safety rules.
</details>