mirror of
https://github.com/notohh/rustlings.git
synced 2024-10-30 16:59:12 -04:00
feat: Add traits README
This commit is contained in:
parent
918f310674
commit
173bb14140
1 changed files with 20 additions and 0 deletions
20
exercises/traits/README.md
Normal file
20
exercises/traits/README.md
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
### Traits
|
||||||
|
|
||||||
|
A trait is a collection of methods.
|
||||||
|
|
||||||
|
Data types can implement traits. To do so, the methods making up the trait are defined for the data type. For example, the `String` data type implements the `From<&str>` trait. This allows a user to write `String::from("hello")`.
|
||||||
|
|
||||||
|
In this way, traits are somewhat similar to Java interfaces and C++ abstract classes.
|
||||||
|
|
||||||
|
Some additional common Rust traits include:
|
||||||
|
|
||||||
|
+ `Clone` (the `clone` method),
|
||||||
|
+ `Display` (which allows formatted display via `{}`), and
|
||||||
|
+ `Debug` (which allows formatted display via `{:?}`).
|
||||||
|
|
||||||
|
Because traits indicate shared behavior between data types, they are useful when writing generics.
|
||||||
|
|
||||||
|
|
||||||
|
#### Book Sections
|
||||||
|
|
||||||
|
- [Traits](https://doc.rust-lang.org/book/ch10-02-traits.html)
|
Loading…
Reference in a new issue