1
0
Fork 0
mirror of https://github.com/rust-lang/rustlings.git synced 2024-05-23 16:56:12 +02:00
This commit is contained in:
Enrico 2024-04-25 19:19:39 +09:00 committed by GitHub
commit dc98db4848
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 79 additions and 2 deletions

View File

@ -1,8 +1,9 @@
# Functions
Here, you'll learn how to write functions and how the Rust compiler can help you debug errors even
in more complex code.
in more complex code. You will also learn what is the difference with closures.
## Further information
- [How Functions Work](https://doc.rust-lang.org/book/ch03-03-how-functions-work.html)
- [Closures](https://doc.rust-lang.org/book/ch13-01-closures.html)

View File

@ -0,0 +1,20 @@
// functions6.rs
//
// Here you can practice special functions called `closures`, that can capture
// variables of their parent context.
// Fix the code below to make it compile, without changing the two closure
// definitions.
//
// Execute `rustlings hint functions6` or use the `hint` watch subcommand for
// some hints.
// I AM NOT DONE
fn main() {
let closure_1 = |input_var: u32| -> u32 {input_var + outer_var};
println!("Closure#1 returns {}", closure_1(5));
let closure_2 = |input_var| println!("Closure#2 (input_var {})", input_var);
closure_2(2);
closure_2("5");
}

View File

@ -0,0 +1,27 @@
// move_semantics6.rs
//
// Here you will practice how mutable/immutable borrowing works in the context
// of a closure.
//
// Try to fix this code to make it compile and not panic.
// You can't change anything except removing 1 line.
//
// Execute `rustlings hint move_semantics7` or use the `hint` watch subcommand
// for a hint.
// I AM NOT DONE
fn main() {
let mut counter = 0;
let mut increment = || {
counter += 1;
println!("counter: {}", counter);
};
increment();
let _reborrowed_counter = &counter;
increment();
assert_eq!(counter, 2);
}

View File

@ -3,7 +3,7 @@
| Exercise | Book Chapter |
| ---------------------- | ------------------- |
| variables | §3.1 |
| functions | §3.3 |
| functions | §3.3, §13.1 |
| if | §3.5 |
| primitive_types | §3.2, §4.3 |
| vecs | §8.1 |

View File

@ -161,6 +161,21 @@ They are not the same. There are two solutions:
1. Add a `return` ahead of `num * num;`
2. remove `;`, make it to be `num * num`"""
[[exercises]]
name = "functions6"
path = "exercises/02_functions/functions6.rs"
mode = "compile"
hint = """
Hint FIX #1: Closures can capture variables defined in the outer context.
Hint FIX #2: Closures can infer both input and returned types, when they are not
specified in the signature. But the closure cannot be reused with different
input types.
Read more about closures in the rust book dedicated section:
https://doc.rust-lang.org/book/ch13-01-closures.html
"""
# IF
[[exercises]]
@ -403,6 +418,20 @@ Can you figure out how?
Another hint: it has to do with the `&` character."""
[[exercises]]
name = "move_semantics7"
path = "exercises/06_move_semantics/move_semantics7.rs"
mode = "compile"
hint = """
When a closure capture a variable to modify it, it borrows that variable as a
mutable reference. In this exercise, as the closure mutably borrows `counter`
and is called later, any attempt to reborrow `counter` in between will lead to
an error.
You cannot immutably borrow a variable if a mutable closure is
called later in the scope.
"""
# STRUCTS
[[exercises]]