Function crossbeam_utils::thread::scope
source · pub fn scope<'env, F, R>(f: F) -> Result<R>
Expand description
Creates a new scope for spawning threads.
All child threads that haven’t been manually joined will be automatically joined just before
this function invocation ends. If all joined threads have successfully completed, Ok
is
returned with the return value of f
. If any of the joined threads has panicked, an Err
is
returned containing errors from panicked threads. Note that if panics are implemented by
aborting the process, no error is returned; see the notes of std::panic::catch_unwind.
Note: Since Rust 1.63, this function is soft-deprecated in favor of the more efficient std::thread::scope
.
Examples
use crossbeam_utils::thread;
let var = vec![1, 2, 3];
thread::scope(|s| {
s.spawn(|_| {
println!("A child thread borrowing `var`: {:?}", var);
});
}).unwrap();