Skip to content

Commit

Permalink
book: reword timer bit
Browse files Browse the repository at this point in the history
  • Loading branch information
Darin Morrison committed Mar 31, 2015
1 parent 80bf31d commit 9ba7974
Showing 1 changed file with 9 additions and 7 deletions.
16 changes: 9 additions & 7 deletions src/doc/trpl/concurrency.md
Expand Up @@ -280,13 +280,15 @@ it returns an `Result<T, E>`, and because this is just an example, we `unwrap()`
it to get a reference to the data. Real code would have more robust error handling
here. We're then free to mutate it, since we have the lock.

This timer bit is a bit awkward, however. We have picked a reasonable amount of
time to wait, but it's entirely possible that we've picked too high, and that
we could be taking less time. It's also possible that we've picked too low,
and that we aren't actually finishing this computation.

Rust's standard library provides a few more mechanisms for two threads to
synchronize with each other. Let's talk about one: channels.
Lastly, while the threads are running, we wait on a short timer. But
this is not ideal: we may have picked a reasonable amount of time to
wait but it's more likely we'll either be waiting longer than
necessary or not long enough, depending on just how much time the
threads actually take to finish computing when the program runs.

A more precise alternative to the timer would be to use one of the
mechanisms provided by the Rust standard library for synchronizing
threads with each other. Let's talk about one of them: channels.

## Channels

Expand Down

0 comments on commit 9ba7974

Please sign in to comment.