Grammar and slight ordering changes
This commit is contained in:
parent
6bf8cc5789
commit
6bbe6759a5
@ -9,7 +9,8 @@ let origin_x = 0;
|
||||
let origin_y = 0;
|
||||
```
|
||||
|
||||
A `struct` lets us combine these two into a single, unified datatype:
|
||||
A `struct` lets us combine these two into a single, unified datatype with `x`
|
||||
and `y` as traits:
|
||||
|
||||
```rust
|
||||
struct Point {
|
||||
@ -18,7 +19,7 @@ struct Point {
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let origin = Point { x: 0, y: 0 }; // origin: Point
|
||||
let origin = Point { x: 0, y: 0 }; // create an instance
|
||||
|
||||
println!("The origin is at ({}, {})", origin.x, origin.y);
|
||||
}
|
||||
@ -32,7 +33,7 @@ We can create an instance of our `struct` via `let`, as usual, but we use a `key
|
||||
value` style syntax to set each field. The order doesn’t need to be the same as
|
||||
in the original declaration.
|
||||
|
||||
Finally, because fields have names, we can access the field through dot
|
||||
Finally, because fields have names, we can access them through dot
|
||||
notation: `origin.x`.
|
||||
|
||||
The values in `struct`s are immutable by default, like other bindings in Rust.
|
||||
@ -67,9 +68,8 @@ struct Point {
|
||||
|
||||
Mutability is a property of the binding, not of the structure itself. If you’re
|
||||
used to field-level mutability, this may seem strange at first, but it
|
||||
significantly simplifies things. It even lets you make things mutable for a short
|
||||
time only:
|
||||
|
||||
significantly simplifies things. It even lets you make things mutable on a temporary
|
||||
basis:
|
||||
|
||||
```rust,ignore
|
||||
struct Point {
|
||||
@ -82,7 +82,7 @@ fn main() {
|
||||
|
||||
point.x = 5;
|
||||
|
||||
let point = point; // this new binding can’t change now
|
||||
let point = point; // now immutable
|
||||
|
||||
point.y = 6; // this causes an error
|
||||
}
|
||||
@ -121,27 +121,24 @@ let point = Point3d { z: 1, x: 2, .. origin };
|
||||
# Tuple structs
|
||||
|
||||
Rust has another data type that’s like a hybrid between a [tuple][tuple] and a
|
||||
`struct`, called a ‘tuple struct’. Tuple structs have a name, but
|
||||
their fields don’t:
|
||||
`struct`, called a ‘tuple struct’. Tuple structs have a name, but their fields
|
||||
don't. They are declared with the `struct` keyword, and then with a name
|
||||
followed by a tuple:
|
||||
|
||||
[tuple]: primitive-types.html#tuples
|
||||
|
||||
```rust
|
||||
struct Color(i32, i32, i32);
|
||||
struct Point(i32, i32, i32);
|
||||
```
|
||||
|
||||
[tuple]: primitive-types.html#tuples
|
||||
|
||||
These two will not be equal, even if they have the same values:
|
||||
|
||||
```rust
|
||||
# struct Color(i32, i32, i32);
|
||||
# struct Point(i32, i32, i32);
|
||||
let black = Color(0, 0, 0);
|
||||
let origin = Point(0, 0, 0);
|
||||
```
|
||||
Here, `black` and `origin` are not equal, even though they contain the same
|
||||
values.
|
||||
|
||||
It is almost always better to use a `struct` than a tuple struct. We would write
|
||||
`Color` and `Point` like this instead:
|
||||
It is almost always better to use a `struct` than a tuple struct. We
|
||||
would write `Color` and `Point` like this instead:
|
||||
|
||||
```rust
|
||||
struct Color {
|
||||
@ -157,13 +154,14 @@ struct Point {
|
||||
}
|
||||
```
|
||||
|
||||
Now, we have actual names, rather than positions. Good names are important,
|
||||
and with a `struct`, we have actual names.
|
||||
Good names are important, and while values in a tuple struct can be
|
||||
referenced with dot notation as well, a `struct` gives us actual names,
|
||||
rather than positions.
|
||||
|
||||
There _is_ one case when a tuple struct is very useful, though, and that’s a
|
||||
tuple struct with only one element. We call this the ‘newtype’ pattern, because
|
||||
it allows you to create a new type, distinct from that of its contained value
|
||||
and expressing its own semantic meaning:
|
||||
There _is_ one case when a tuple struct is very useful, though, and that is when
|
||||
it has only one element. We call this the ‘newtype’ pattern, because
|
||||
it allows you to create a new type that is distinct from its contained value
|
||||
and also expresses its own semantic meaning:
|
||||
|
||||
```rust
|
||||
struct Inches(i32);
|
||||
|
Loading…
Reference in New Issue
Block a user