Struct bevy::tasks::ThreadExecutor

pub struct ThreadExecutor<'task> { /* private fields */ }
Expand description

An executor that can only be ticked on the thread it was instantiated on. But can spawn Send tasks from other threads.

Example

use bevy_tasks::ThreadExecutor;

let thread_executor = ThreadExecutor::new();
let count = Arc::new(AtomicI32::new(0));

// create some owned values that can be moved into another thread
let count_clone = count.clone();

std::thread::scope(|scope| {
    scope.spawn(|| {
        // we cannot get the ticker from another thread
        let not_thread_ticker = thread_executor.ticker();
        assert!(not_thread_ticker.is_none());
         
        // but we can spawn tasks from another thread
        thread_executor.spawn(async move {
            count_clone.fetch_add(1, Ordering::Relaxed);
        }).detach();
    });
});

// the tasks do not make progress unless the executor is manually ticked
assert_eq!(count.load(Ordering::Relaxed), 0);

// tick the ticker until task finishes
let thread_ticker = thread_executor.ticker().unwrap();
thread_ticker.try_tick();
assert_eq!(count.load(Ordering::Relaxed), 1);

Implementations§

§

impl<'task> ThreadExecutor<'task>

pub fn new() -> ThreadExecutor<'task>

create a new ThreadExecutor

pub fn spawn<T>(&self, future: impl Future<Output = T> + Send + 'task) -> Task<T>where T: Send + 'task,

Spawn a task on the thread executor

pub fn ticker<'ticker>( &'ticker self ) -> Option<ThreadExecutorTicker<'task, 'ticker>>

Gets the ThreadExecutorTicker for this executor. Use this to tick the executor. It only returns the ticker if it’s on the thread the executor was created on and returns None otherwise.

pub fn is_same(&self, other: &ThreadExecutor<'task>) -> bool

Returns true if self and other’s executor is same

Trait Implementations§

§

impl<'task> Debug for ThreadExecutor<'task>

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

impl<'task> Default for ThreadExecutor<'task>

§

fn default() -> ThreadExecutor<'task>

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<'task> RefUnwindSafe for ThreadExecutor<'task>

§

impl<'task> Send for ThreadExecutor<'task>

§

impl<'task> Sync for ThreadExecutor<'task>

§

impl<'task> Unpin for ThreadExecutor<'task>

§

impl<'task> UnwindSafe for ThreadExecutor<'task>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T, U> AsBindGroupShaderType<U> for Twhere U: ShaderType, &'a T: for<'a> Into<U>,

§

fn as_bind_group_shader_type(&self, _images: &RenderAssets<Image>) -> U

Return the T ShaderType for self. When used in AsBindGroup derives, it is safe to assume that all images in self exist.
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
§

impl<T> Downcast<T> for T

§

fn downcast(&self) -> &T

§

impl<T> Downcast for Twhere T: Any,

§

fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>

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

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

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

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

impl<T> DowncastSync for Twhere T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send + 'static>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<S> FromSample<S> for S

§

fn from_sample_(s: S) -> S

§

impl<T> FromWorld for Twhere T: Default,

§

fn from_world(_world: &mut World) -> T

Creates Self using data from the given World
source§

impl<T> Instrument for T

source§

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

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

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 Twhere U: From<T>,

const: unstable · 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.

§

impl<T, U> ToSample<U> for Twhere U: FromSample<T>,

§

fn to_sample_(self) -> U

source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · 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.
const: unstable · source§

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

Performs the conversion.
§

impl<T> Upcast<T> for T

§

fn upcast(&self) -> Option<&T>

source§

impl<T> WithSubscriber for T

source§

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

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<S, T> Duplex<S> for Twhere T: FromSample<S> + ToSample<S>,

§

impl<T> Event for Twhere T: Send + Sync + 'static,