pub struct StaticKey {
    key: AtomicUsize,
    dtor: Option<unsafe extern "C" fn(_: *mut u8)>,
}
🔬This is a nightly-only experimental API. (thread_local_internals)
Expand description

A type for TLS keys that are statically allocated.

This type is entirely unsafe to use as it does not protect against use-after-deallocation or use-during-deallocation.

The actual OS-TLS key is lazily allocated when this is used for the first time. The key is also deallocated when the Rust runtime exits or destroy is called, whichever comes first.

Examples

use tls::os::{StaticKey, INIT};

// Use a regular global static to store the key.
static KEY: StaticKey = INIT;

// The state provided via `get` and `set` is thread-local.
unsafe {
    assert!(KEY.get().is_null());
    KEY.set(1 as *mut u8);
}
Run

Fields§

§key: AtomicUsize
🔬This is a nightly-only experimental API. (thread_local_internals)

Inner static TLS key (internals).

§dtor: Option<unsafe extern "C" fn(_: *mut u8)>
🔬This is a nightly-only experimental API. (thread_local_internals)

Destructor for the TLS value.

See Key::new for information about when the destructor runs and how it runs.

Implementations§

source§

impl StaticKey

const: unstable · source

pub fn new(dtor: Option<unsafe extern "C" fn(_: *mut u8)>) -> StaticKey

🔬This is a nightly-only experimental API. (thread_local_internals)
source

pub unsafe fn get(&self) -> *mut u8

🔬This is a nightly-only experimental API. (thread_local_internals)

Gets the value associated with this TLS key

This will lazily allocate a TLS key from the OS if one has not already been allocated.

source

pub unsafe fn set(&self, val: *mut u8)

🔬This is a nightly-only experimental API. (thread_local_internals)

Sets this TLS key to a new value.

This will lazily allocate a TLS key from the OS if one has not already been allocated.

source

unsafe fn key(&self) -> pthread_key_t

🔬This is a nightly-only experimental API. (thread_local_internals)
source

unsafe fn lazy_init(&self) -> usize

🔬This is a nightly-only experimental API. (thread_local_internals)

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.