no_std_compat::thread

Function add_spawn_hook

Source
pub fn add_spawn_hook<F, G>(hook: F)
where F: 'static + Send + Sync + Fn(&Thread) -> G, G: 'static + Send + FnOnce(),
🔬This is a nightly-only experimental API. (thread_spawn_hook)
Expand description

Registers a function to run for every newly thread spawned.

The hook is executed in the parent thread, and returns a function that will be executed in the new thread.

The hook is called with the Thread handle for the new thread.

The hook will only be added for the current thread and is inherited by the threads it spawns. In other words, adding a hook has no effect on already running threads (other than the current thread) and the threads they might spawn in the future.

Hooks can only be added, not removed.

The hooks will run in reverse order, starting with the most recently added.

§Usage

#![feature(thread_spawn_hook)]

std::thread::add_spawn_hook(|_| {
    ..; // This will run in the parent (spawning) thread.
    move || {
        ..; // This will run it the child (spawned) thread.
    }
});

§Example

A spawn hook can be used to “inherit” a thread local from the parent thread:

#![feature(thread_spawn_hook)]

use std::cell::Cell;

thread_local! {
    static X: Cell<u32> = Cell::new(0);
}

// This needs to be done once in the main thread before spawning any threads.
std::thread::add_spawn_hook(|_| {
    // Get the value of X in the spawning thread.
    let value = X.get();
    // Set the value of X in the newly spawned thread.
    move || X.set(value)
});

X.set(123);

std::thread::spawn(|| {
    assert_eq!(X.get(), 123);
}).join().unwrap();