rust-by-practice/en/src/basic-types/functions.md

101 lines
1.7 KiB
Markdown

# Functions
1. 🌟🌟🌟
```rust,editable
fn main() {
// don't modify the following two lines!
let (x, y) = (1, 2);
let s = sum(x, y);
assert_eq!(s, 3);
println!("Success!")
}
fn sum(x, y: i32) {
x + y;
}
```
2. 🌟
```rust,editable
fn main() {
print();
}
// replace i32 with another type
fn print() -> i32 {
println!("Success!")
}
```
3. 🌟🌟🌟
```rust,editable
// solve it in two ways
// DON'T let `println!` works
fn main() {
never_return();
println!("Failed!")
}
fn never_return() -> ! {
// implement this function, don't modify the fn signatures
}
```
### Diverging functions
Diverging functions never return to the caller, so they may be used in places where a value of any type is expected.
4. 🌟🌟
```rust,editable
fn main() {
println!("Success!");
}
fn get_option(tp: u8) -> Option<i32> {
match tp {
1 => {
// TODO
}
_ => {
// TODO
}
};
// Rather than returning a None, we use a diverging function instead
never_return_fn()
}
// IMPLEMENT this function in THREE ways
fn never_return_fn() -> ! {
}
```
5. 🌟🌟
```rust,editable
fn main() {
// FILL in the blank
let b = __;
let v = match b {
true => 1,
// Diverging functions can also be used in match expression to replace a value of any value
false => {
println!("Success!");
panic!("we have no value for `false`, but we can panic")
}
};
println!("Excercise Failed if printing out this line!");
}
```
> 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