rust-by-practice/src/variables.md

150 lines
2.8 KiB
Markdown
Raw Normal View History

# Variables
2022-02-24 01:50:01 -06:00
### Binding and mutablity
2022-03-01 07:56:43 -06:00
1. 🌟 A variable can be used only if it has been initialized.
2022-02-24 01:50:01 -06:00
```rust,editable
2022-02-28 02:48:07 -06:00
// fix the error below with least modifying
2022-02-24 01:50:01 -06:00
fn main() {
let x: i32; // uninitialized but using, ERROR !
let y: i32; // uninitialized but also unusing, only warning
println!("{} is equal to 5", x);
}
```
2022-03-01 07:56:43 -06:00
2. 🌟 Use `mut` to mark a variable as mutable.
2022-02-24 01:50:01 -06:00
```rust,editable
2022-02-28 02:48:07 -06:00
// fill the blanks in code to make it compile
2022-02-24 01:50:01 -06:00
fn main() {
let __ = 1;
__ += 2;
println!("{} is equal to 3", x);
}
```
### Scope
2022-02-28 02:57:04 -06:00
A scope is the range within the program for which the item is valid.
2022-03-01 07:56:43 -06:00
3. 🌟
2022-03-04 06:52:30 -06:00
```rust,editable
2022-02-24 01:50:01 -06:00
2022-02-28 02:48:07 -06:00
// fix the error below with least modifying
2022-02-24 01:50:01 -06:00
fn main() {
let x: i32 = 10;
{
let y: i32 = 5;
println!("The value of x is {} and value of y is {}", x, y);
}
println!("The value of x is {} and value of y is {}", x, y);
}
```
2022-03-01 07:56:43 -06:00
4. 🌟🌟
2022-02-24 01:50:01 -06:00
```rust,editable
2022-03-01 07:56:43 -06:00
// fix the error with using of define_x
2022-02-24 01:50:01 -06:00
fn main() {
println!("{}, world", x);
}
fn define_x() {
let x = "hello";
}
```
### Shadowing
2022-02-28 02:57:04 -06:00
You can declare a new variable with the same name as a previous variable, here we can say **the first one is shadowed by the second one.
2022-02-24 01:50:01 -06:00
2022-03-01 07:56:43 -06:00
5. 🌟🌟
2022-02-24 01:50:01 -06:00
```rust,editable
2022-02-28 02:48:07 -06:00
// only modify `assert_eq!` to make the `println!` work(print `42` in terminal)
2022-02-24 01:50:01 -06:00
fn main() {
let x: i32 = 5;
{
let x = 12;
assert_eq!(x, 5);
}
assert_eq!(x, 12);
let x = 42;
println!("{}", x); // Prints "42".
}
```
2022-03-01 07:56:43 -06:00
6. 🌟🌟
2022-02-24 01:50:01 -06:00
```rust,editable
2022-02-28 02:57:04 -06:00
// remove a line in code to make it compile
2022-02-24 01:50:01 -06:00
fn main() {
let mut x: i32 = 1;
x = 7;
// shadowing and re-binding
let x = x;
x += 3;
let y = 4;
// shadowing
let y = "I can also be bound to text!";
}
```
### Unused varibles
2022-03-02 02:37:02 -06:00
1. fix the warning below with :
2022-02-24 01:50:01 -06:00
2022-03-02 02:37:02 -06:00
- 🌟 only one solution
- 🌟🌟 two distinct solutions
2022-02-24 01:50:01 -06:00
2022-03-02 02:37:02 -06:00
> Note: none of the solutions is to remove the line `let x = 1`
2022-02-24 01:50:01 -06:00
```rust,editable
fn main() {
let x = 1;
}
// warning: unused variable: `x`
```
2022-02-28 02:57:04 -06:00
### Destructuring
2022-03-01 07:56:43 -06:00
8. 🌟🌟 We can use a pattern with `let` to destructure a tuple to separate variables.
2022-02-24 01:50:01 -06:00
> Tips: you can use Shadowing or Mutability
```rust,editable
2022-02-28 02:57:04 -06:00
// fix the error below with least modifying
2022-02-24 01:50:01 -06:00
fn main() {
let (x, y) = (1, 2);
x += 2;
assert_eq!(x, 3);
assert_eq!(y, 2);
}
2022-02-24 21:18:27 -06:00
```
### Destructuring assignments
2022-02-28 02:57:04 -06:00
Introducing in Rust 1.59: You can now use tuple, slice, and struct patterns as the left-hand side of an assignment.
2022-02-24 21:18:27 -06:00
2022-03-01 07:56:43 -06:00
9. 🌟🌟
2022-02-24 21:18:27 -06:00
> Note: the feature `Destructuring assignments` need 1.59 or higher Rust version
```rust,editable
fn main() {
2022-02-28 02:57:04 -06:00
let (x, y);
(x,..) = (3, 4);
[.., y] = [1, 2];
// fill the blank to make the code work
assert_eq!([x,y], __);
2022-02-24 21:18:27 -06:00
}
2022-03-01 08:06:38 -06:00
```
2022-03-04 06:52:30 -06:00
> You can find the solutions [here](https://github.com/sunface/rust-by-practice)(under the solutions path), but only use it when you need it