pub struct Builder { /* fields omitted */ }
Thread factory, which can be used in order to configure the properties of a new thread.
Methods can be chained on it in order to configure it.
The two configurations available are:
name
: specifies an associated name for the thread
stack_size
: specifies the desired stack size for the thread
The spawn
method will take ownership of the builder and create an io::Result
to the thread handle with the given configuration.
The thread::spawn
free function uses a Builder
with default configuration and unwrap
s its return value.
You may want to use spawn
instead of thread::spawn
, when you want to recover from a failure to launch a thread, indeed the free function will panic where the Builder
method will return a io::Result
.
use std::thread; let builder = thread::Builder::new(); let handler = builder.spawn(|| { // thread code }).unwrap(); handler.join().unwrap();
impl Builder
[src]
pub fn new() -> Builder
[src]
Generates the base configuration for spawning a thread, from which configuration methods can be chained.
use std::thread; let builder = thread::Builder::new() .name("foo".into()) .stack_size(32 * 1024); let handler = builder.spawn(|| { // thread code }).unwrap(); handler.join().unwrap();
pub fn name(self, name: String) -> Builder
[src]
Names the thread-to-be. Currently the name is used for identification only in panic messages.
The name must not contain null bytes (\0
).
For more information about named threads, see this module-level documentation.
use std::thread; let builder = thread::Builder::new() .name("foo".into()); let handler = builder.spawn(|| { assert_eq!(thread::current().name(), Some("foo")) }).unwrap(); handler.join().unwrap();
pub fn stack_size(self, size: usize) -> Builder
[src]
Sets the size of the stack (in bytes) for the new thread.
The actual stack size may be greater than this value if the platform specifies a minimal stack size.
For more information about the stack size for threads, see this module-level documentation.
use std::thread; let builder = thread::Builder::new().stack_size(32 * 1024);
pub fn spawn<F, T>(self, f: F) -> Result<JoinHandle<T>> where
F: FnOnce() -> T,
F: Send + 'static,
T: Send + 'static,
[src]
Spawns a new thread by taking ownership of the Builder
, and returns an io::Result
to its JoinHandle
.
The spawned thread may outlive the caller (unless the caller thread is the main thread; the whole process is terminated when the main thread finishes). The join handle can be used to block on termination of the child thread, including recovering its panics.
For a more complete documentation see thread::spawn
.
Unlike the spawn
free function, this method yields an io::Result
to capture any failure to create the thread at the OS level.
Panics if a thread name was set and it contained null bytes.
use std::thread; let builder = thread::Builder::new(); let handler = builder.spawn(|| { // thread code }).unwrap(); handler.join().unwrap();
pub unsafe fn spawn_unchecked<'a, F, T>(self, f: F) -> Result<JoinHandle<T>> where
F: FnOnce() -> T,
F: Send + 'a,
T: Send + 'a,
[src]
Spawns a new thread without any lifetime restrictions by taking ownership of the Builder
, and returns an io::Result
to its JoinHandle
.
The spawned thread may outlive the caller (unless the caller thread is the main thread; the whole process is terminated when the main thread finishes). The join handle can be used to block on termination of the child thread, including recovering its panics.
This method is identical to thread::Builder::spawn
, except for the relaxed lifetime bounds, which render it unsafe. For a more complete documentation see thread::spawn
.
Unlike the spawn
free function, this method yields an io::Result
to capture any failure to create the thread at the OS level.
Panics if a thread name was set and it contained null bytes.
The caller has to ensure that no references in the supplied thread closure or its return type can outlive the spawned thread's lifetime. This can be guaranteed in two ways:
join
is called before any referenced data is dropped'static
lifetime bounds, i.e., those with no or only 'static
references (both thread::Builder::spawn
and thread::spawn
enforce this property statically)#![feature(thread_spawn_unchecked)] use std::thread; let builder = thread::Builder::new(); let x = 1; let thread_x = &x; let handler = unsafe { builder.spawn_unchecked(move || { println!("x = {}", *thread_x); }).unwrap() }; // caller has to ensure `join()` is called, otherwise // it is possible to access freed memory if `x` gets // dropped before the thread closure is executed! handler.join().unwrap();
impl RefUnwindSafe for Builder
impl Send for Builder
impl Sync for Builder
impl Unpin for Builder
impl UnwindSafe for Builder
impl<T> Any for T where
T: 'static + ?Sized,
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
fn borrow(&self) -> &TⓘNotable traits for &'_ mut F
impl<'_, F> Future for &'_ mut F where
F: Unpin + Future + ?Sized,
type Output = <F as Future>::Output;
impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized,
type Item = <I as Iterator>::Item;
impl<R: Read + ?Sized, '_> Read for &'_ mut R
impl<W: Write + ?Sized, '_> Write for &'_ mut W
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
fn borrow_mut(&mut self) -> &mut TⓘNotable traits for &'_ mut F
impl<'_, F> Future for &'_ mut F where
F: Unpin + Future + ?Sized,
type Output = <F as Future>::Output;
impl<'_, I> Iterator for &'_ mut I where
I: Iterator + ?Sized,
type Item = <I as Iterator>::Item;
impl<R: Read + ?Sized, '_> Read for &'_ mut R
impl<W: Write + ?Sized, '_> Write for &'_ mut W
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/thread/struct.Builder.html