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 will be seeing mostly safe Rust in this course, but it's important to know
|
2023-01-02 10:30:40 +01:00
|
|
|
what Unsafe Rust is.
|
2022-12-21 16:36:30 +01:00
|
|
|
|
2023-01-30 13:12:51 +00: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.
|
2023-01-02 10:30:40 +01:00
|
|
|
* Call `unsafe` functions, including `extern` functions.
|
2022-12-21 16:36:30 +01:00
|
|
|
* Implement `unsafe` traits.
|
|
|
|
|
2023-01-30 13:12:51 +00:00
|
|
|
We will briefly cover unsafe capabilities next. For full details, please see
|
2023-01-02 10:30:40 +01:00
|
|
|
[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/).
|
2023-01-30 13:12:51 +00:00
|
|
|
|
|
|
|
<details>
|
|
|
|
|
|
|
|
Unsafe Rust does not mean the code is incorrect. It means that developers have
|
|
|
|
turned off the compiler safety features and have to write correct code by
|
|
|
|
themselves. It means the compiler no longer enforces Rust's memory-safety rules.
|
|
|
|
|
|
|
|
</details>
|