2022-07-15 13:01:32 +01:00
|
|
|
# Lifetimes
|
|
|
|
|
|
|
|
Lifetimes tell the compiler how to check whether references live long
|
|
|
|
enough to be valid in any given situation. For example lifetimes say
|
|
|
|
"make sure parameter 'a' lives as long as parameter 'b' so that the return
|
|
|
|
value is valid".
|
|
|
|
|
|
|
|
They are only necessary on borrows, i.e. references,
|
|
|
|
since copied parameters or moves are owned in their scope and cannot
|
|
|
|
be referenced outside. Lifetimes mean that calling code of e.g. functions
|
|
|
|
can be checked to make sure their arguments are valid. Lifetimes are
|
|
|
|
restrictive of their callers.
|
|
|
|
|
|
|
|
## Further information
|
|
|
|
|
|
|
|
- [Lifetimes (in Rust By Example)](https://doc.rust-lang.org/stable/rust-by-example/scope/lifetime.html)
|
2023-03-15 23:56:15 +00:00
|
|
|
- [Validating References with Lifetimes](https://doc.rust-lang.org/book/ch10-03-lifetime-syntax.html)
|