Grammar and slight ordering changes

This commit is contained in:
Xmasreturns 2015-12-09 11:37:57 -08:00
parent 6bf8cc5789
commit 6bbe6759a5

View File

@ -9,7 +9,8 @@ let origin_x = 0;
let origin_y = 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 ```rust
struct Point { struct Point {
@ -18,7 +19,7 @@ struct Point {
} }
fn main() { 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); 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 doesnt need to be the same as value` style syntax to set each field. The order doesnt need to be the same as
in the original declaration. 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`. notation: `origin.x`.
The values in `struct`s are immutable by default, like other bindings in Rust. 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 youre Mutability is a property of the binding, not of the structure itself. If youre
used to field-level mutability, this may seem strange at first, but it 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 significantly simplifies things. It even lets you make things mutable on a temporary
time only: basis:
```rust,ignore ```rust,ignore
struct Point { struct Point {
@ -82,7 +82,7 @@ fn main() {
point.x = 5; point.x = 5;
let point = point; // this new binding cant change now let point = point; // now immutable
point.y = 6; // this causes an error point.y = 6; // this causes an error
} }
@ -121,27 +121,24 @@ let point = Point3d { z: 1, x: 2, .. origin };
# Tuple structs # Tuple structs
Rust has another data type thats like a hybrid between a [tuple][tuple] and a Rust has another data type thats like a hybrid between a [tuple][tuple] and a
`struct`, called a tuple struct. Tuple structs have a name, but `struct`, called a tuple struct. Tuple structs have a name, but their fields
their fields dont: don't. They are declared with the `struct` keyword, and then with a name
followed by a tuple:
[tuple]: primitive-types.html#tuples
```rust ```rust
struct Color(i32, i32, i32); struct Color(i32, i32, i32);
struct Point(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 black = Color(0, 0, 0);
let origin = Point(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 It is almost always better to use a `struct` than a tuple struct. We
`Color` and `Point` like this instead: would write `Color` and `Point` like this instead:
```rust ```rust
struct Color { struct Color {
@ -157,13 +154,14 @@ struct Point {
} }
``` ```
Now, we have actual names, rather than positions. Good names are important, Good names are important, and while values in a tuple struct can be
and with a `struct`, we have actual names. 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 thats a There _is_ one case when a tuple struct is very useful, though, and that is when
tuple struct with only one element. We call this the newtype pattern, because it has 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 it allows you to create a new type that is distinct from its contained value
and expressing its own semantic meaning: and also expresses its own semantic meaning:
```rust ```rust
struct Inches(i32); struct Inches(i32);