Struct otter_nodejs_tests::thread::Builder  
1.0.0 · source · [−]pub struct Builder { /* private fields */ }Expand description
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 unwraps 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.
Examples
use std::thread;
let builder = thread::Builder::new();
let handler = builder.spawn(|| {
    // thread code
}).unwrap();
handler.join().unwrap();Implementations
sourceimpl Builder
 
impl Builder
sourcepub fn spawn_scoped<'scope, F, T>(
    self, 
    scope: &'scope Scope<'scope, 'env>, 
    f: F
) -> Result<ScopedJoinHandle<'scope, T>, Error> where
    F: 'scope + FnOnce() -> T + Send,
    T: 'scope + Send, 
 🔬 This is a nightly-only experimental API. (scoped_threads)
pub fn spawn_scoped<'scope, F, T>(
    self, 
    scope: &'scope Scope<'scope, 'env>, 
    f: F
) -> Result<ScopedJoinHandle<'scope, T>, Error> where
    F: 'scope + FnOnce() -> T + Send,
    T: 'scope + Send, 
scoped_threads)Spawns a new scoped thread using the settings set through this Builder.
Unlike Scope::spawn, this method yields an io::Result to
capture any failure to create the thread at the OS level.
Panics
Panics if a thread name was set and it contained null bytes.
Example
#![feature(scoped_threads)]
use std::thread;
let mut a = vec![1, 2, 3];
let mut x = 0;
thread::scope(|s| {
    thread::Builder::new()
        .name("first".to_string())
        .spawn_scoped(s, ||
    {
        println!("hello from the {:?} scoped thread", thread::current().name());
        // We can borrow `a` here.
        dbg!(&a);
    })
    .unwrap();
    thread::Builder::new()
        .name("second".to_string())
        .spawn_scoped(s, ||
    {
        println!("hello from the {:?} scoped thread", thread::current().name());
        // We can even mutably borrow `x` here,
        // because no other threads are using it.
        x += a[0] + a[2];
    })
    .unwrap();
    println!("hello from the main thread");
});
// After the scope, we can modify and access our variables again:
a.push(4);
assert_eq!(x, a.len());sourceimpl Builder
 
impl Builder
sourcepub fn new() -> Builder
 
pub fn new() -> Builder
Generates the base configuration for spawning a thread, from which configuration methods can be chained.
Examples
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();sourcepub fn name(self, name: String) -> Builder
 
pub fn name(self, name: String) -> Builder
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.
Examples
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();sourcepub fn stack_size(self, size: usize) -> Builder
 
pub fn stack_size(self, size: usize) -> Builder
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.
Examples
use std::thread;
let builder = thread::Builder::new().stack_size(32 * 1024);sourcepub fn spawn<F, T>(self, f: F) -> Result<JoinHandle<T>, Error> where
    F: FnOnce() -> T + 'static + Send,
    T: 'static + Send, 
 
pub fn spawn<F, T>(self, f: F) -> Result<JoinHandle<T>, Error> where
    F: FnOnce() -> T + 'static + Send,
    T: 'static + Send, 
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 spawned thread, including recovering its panics.
For a more complete documentation see thread::spawn.
Errors
Unlike the spawn free function, this method yields an
io::Result to capture any failure to create the thread at
the OS level.
Panics
Panics if a thread name was set and it contained null bytes.
Examples
use std::thread;
let builder = thread::Builder::new();
let handler = builder.spawn(|| {
    // thread code
}).unwrap();
handler.join().unwrap();sourcepub unsafe fn spawn_unchecked<'a, F, T>(
    self, 
    f: F
) -> Result<JoinHandle<T>, Error> where
    F: FnOnce() -> T + 'a + Send,
    T: 'a + Send, 
 🔬 This is a nightly-only experimental API. (thread_spawn_unchecked)
pub unsafe fn spawn_unchecked<'a, F, T>(
    self, 
    f: F
) -> Result<JoinHandle<T>, Error> where
    F: FnOnce() -> T + 'a + Send,
    T: 'a + Send, 
thread_spawn_unchecked)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 spawned 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.
Errors
Unlike the spawn free function, this method yields an
io::Result to capture any failure to create the thread at
the OS level.
Panics
Panics if a thread name was set and it contained null bytes.
Safety
The caller has to ensure that the spawned thread does not outlive any references in the supplied thread closure and its return type. This can be guaranteed in two ways:
- ensure that joinis called before any referenced data is dropped
- use only types with 'staticlifetime bounds, i.e., those with no or only'staticreferences (boththread::Builder::spawnandthread::spawnenforce this property statically)
Examples
#![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();Trait Implementations
Auto Trait Implementations
impl RefUnwindSafe for Builder
impl Send for Builder
impl Sync for Builder
impl Unpin for Builder
impl UnwindSafe for Builder
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
    T: ?Sized, 
 
impl<T> BorrowMut<T> for T where
    T: ?Sized, 
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
impl<T> Downcast for T where
    T: Any, 
impl<T> Downcast for T where
    T: Any, 
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘNotable traits for Box<R, Global>impl<R> Read for Box<R, Global> where
    R: Read + ?Sized, impl<W> Write for Box<W, Global> where
    W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
    F: Future + Unpin + ?Sized,
    A: Allocator + 'static,     type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
    I: Iterator + ?Sized,
    A: Allocator,     type Item = <I as Iterator>::Item;
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘNotable traits for Box<R, Global>impl<R> Read for Box<R, Global> where
    R: Read + ?Sized, impl<W> Write for Box<W, Global> where
    W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
    F: Future + Unpin + ?Sized,
    A: Allocator + 'static,     type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
    I: Iterator + ?Sized,
    A: Allocator,     type Item = <I as Iterator>::Item;
R: Read + ?Sized, impl<W> Write for Box<W, Global> where
W: Write + ?Sized, impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;
Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait. Read more
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait. Read more
fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s. Read more
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s. Read more
impl<A> DynCastExt for A
impl<A> DynCastExt for A
fn dyn_cast<T>(
    self
) -> Result<<A as DynCastExtHelper<T>>::Target, <A as DynCastExtHelper<T>>::Source> where
    A: DynCastExtHelper<T>,
    T: ?Sized, 
fn dyn_cast<T>(
    self
) -> Result<<A as DynCastExtHelper<T>>::Target, <A as DynCastExtHelper<T>>::Source> where
    A: DynCastExtHelper<T>,
    T: ?Sized, 
Use this to cast from one trait object type to another. Read more
fn dyn_upcast<T>(self) -> <A as DynCastExtAdvHelper<T, T>>::Target where
    A: DynCastExtAdvHelper<T, T, Source = <A as DynCastExtAdvHelper<T, T>>::Target>,
    T: ?Sized, 
fn dyn_upcast<T>(self) -> <A as DynCastExtAdvHelper<T, T>>::Target where
    A: DynCastExtAdvHelper<T, T, Source = <A as DynCastExtAdvHelper<T, T>>::Target>,
    T: ?Sized, 
Use this to upcast a trait to one of its supertraits. Read more
fn dyn_cast_adv<F, T>(
    self
) -> Result<<A as DynCastExtAdvHelper<F, T>>::Target, <A as DynCastExtAdvHelper<F, T>>::Source> where
    A: DynCastExtAdvHelper<F, T>,
    F: ?Sized,
    T: ?Sized, 
fn dyn_cast_adv<F, T>(
    self
) -> Result<<A as DynCastExtAdvHelper<F, T>>::Target, <A as DynCastExtAdvHelper<F, T>>::Source> where
    A: DynCastExtAdvHelper<F, T>,
    F: ?Sized,
    T: ?Sized, 
fn dyn_cast_with_config<C>(
    self
) -> Result<<A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Target, <A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Source> where
    C: DynCastConfig,
    A: DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>, 
fn dyn_cast_with_config<C>(
    self
) -> Result<<A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Target, <A as DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>>::Source> where
    C: DynCastConfig,
    A: DynCastExtAdvHelper<<C as DynCastConfig>::Source, <C as DynCastConfig>::Target>, 
Use this to cast from one trait object type to another. With this method the type parameter is a config type that uniquely specifies which cast should be preformed. Read more
sourceimpl<T> Instrument for T
 
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
    T: Future,     type Output = <T as Future>::Output;
 
fn instrument(self, span: Span) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
    T: Future,     type Output = <T as Future>::Output;
T: Future, type Output = <T as Future>::Output;
sourcefn in_current_span(self) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
    T: Future,     type Output = <T as Future>::Output;
 
fn in_current_span(self) -> Instrumented<Self>ⓘNotable traits for Instrumented<T>impl<T> Future for Instrumented<T> where
    T: Future,     type Output = <T as Future>::Output;
T: Future, type Output = <T as Future>::Output;
impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 
impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 
fn vzip(self) -> V
sourceimpl<T> WithSubscriber for T
 
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
    T: Future,     type Output = <T as Future>::Output; where
    S: Into<Dispatch>, 
 
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
    T: Future,     type Output = <T as Future>::Output; where
    S: Into<Dispatch>, 
T: Future, type Output = <T as Future>::Output;
Attaches the provided Subscriber to this type, returning a
WithDispatch wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
    T: Future,     type Output = <T as Future>::Output;
 
fn with_current_subscriber(self) -> WithDispatch<Self>ⓘNotable traits for WithDispatch<T>impl<T> Future for WithDispatch<T> where
    T: Future,     type Output = <T as Future>::Output;
T: Future, type Output = <T as Future>::Output;
Attaches the current default Subscriber to this type, returning a
WithDispatch wrapper. Read more