Skip to main content

EnteredCriticalSection

Struct EnteredCriticalSection 

pub struct EnteredCriticalSection<'a, T>(/* private fields */);
Available on Py_3_14 and non-Py_LIMITED_API and crate feature tls only.
Expand description

Allows access to data protected by a PyMutex in a critical section

Used with the with_critical_section_mutex and with_critical_section_mutex2 functions. See the documentation of those functions for more details.

Implementations§

§

impl<T> EnteredCriticalSection<'_, T>

pub unsafe fn get_mut(&mut self) -> &mut T

Get a mutable reference to the data wrapped by a PyMutex

§Safety

The caller must ensure the closure cannot implicitly release the critical section.

If a multithreaded program calls back into the Python interpreter in a manner that would cause the critical section to be released, the PyMutex will be unlocked and the resource protected by the PyMutex may be read from or modified by another thread while the critical section is suspended. Concurrent modifications are impossible, but races are possible and the state of the protected resource may change in possibly surprising ways after calls into the interpreter.

pub unsafe fn get(&self) -> &T

Get a immutable reference to the value wrapped by a PyMutex

§Safety

The caller must ensure the critical section is not released while the reference is alive. If a multithreaded program calls back into the Python interpreter in a manner that would cause the critical section to be released, the PyMutex will be unlocked and the resource protected by the PyMutex may be read from or modified by another thread while the critical section is suspended and the thread that owns the reference is blocked. Concurrent modifications are impossible, but races are possible and the state of an object may change “underneath” a suspended thread in possibly surprising ways. Note that many operations on Python objects may call back into the interpreter in a blocking manner because many C API calls can trigger the execution of arbitrary Python code.

Auto Trait Implementations§

§

impl<'a, T> Freeze for EnteredCriticalSection<'a, T>

§

impl<'a, T> !RefUnwindSafe for EnteredCriticalSection<'a, T>

§

impl<'a, T> !Send for EnteredCriticalSection<'a, T>

§

impl<'a, T> !Sync for EnteredCriticalSection<'a, T>

§

impl<'a, T> Unpin for EnteredCriticalSection<'a, T>

§

impl<'a, T> UnsafeUnpin for EnteredCriticalSection<'a, T>

§

impl<'a, T> !UnwindSafe for EnteredCriticalSection<'a, T>

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where 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.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where 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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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 T
where U: TryFrom<T>,

Source§

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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more