[−][src]Struct crossbeam::deque::Stealer
A stealer handle of a worker queue.
Stealers can be shared among threads.
Task schedulers typically have a single worker queue per worker thread.
Examples
use crossbeam_deque::{Steal, Worker}; let w = Worker::new_lifo(); w.push(1); w.push(2); let s = w.stealer(); assert_eq!(s.steal(), Steal::Success(1)); assert_eq!(s.steal(), Steal::Success(2)); assert_eq!(s.steal(), Steal::Empty);
Methods
impl<T> Stealer<T>
[src]
pub fn is_empty(&self) -> bool
[src]
Returns true
if the queue is empty.
use crossbeam_deque::Worker; let w = Worker::new_lifo(); let s = w.stealer(); assert!(s.is_empty()); w.push(1); assert!(!s.is_empty());
pub fn steal(&self) -> Steal<T>
[src]
Steals a task from the queue.
Examples
use crossbeam_deque::{Steal, Worker}; let w = Worker::new_lifo(); w.push(1); w.push(2); let s = w.stealer(); assert_eq!(s.steal(), Steal::Success(1)); assert_eq!(s.steal(), Steal::Success(2));
pub fn steal_batch(&self, dest: &Worker<T>) -> Steal<()>
[src]
Steals a batch of tasks and pushes them into another worker.
How many tasks exactly will be stolen is not specified. That said, this method will try to steal around half of the tasks in the queue, but also not more than some constant limit.
Examples
use crossbeam_deque::Worker; let w1 = Worker::new_fifo(); w1.push(1); w1.push(2); w1.push(3); w1.push(4); let s = w1.stealer(); let w2 = Worker::new_fifo(); s.steal_batch(&w2); assert_eq!(w2.pop(), Some(1)); assert_eq!(w2.pop(), Some(2));
pub fn steal_batch_and_pop(&self, dest: &Worker<T>) -> Steal<T>
[src]
Steals a batch of tasks, pushes them into another worker, and pops a task from that worker.
How many tasks exactly will be stolen is not specified. That said, this method will try to steal around half of the tasks in the queue, but also not more than some constant limit.
Examples
use crossbeam_deque::{Steal, Worker}; let w1 = Worker::new_fifo(); w1.push(1); w1.push(2); w1.push(3); w1.push(4); let s = w1.stealer(); let w2 = Worker::new_fifo(); assert_eq!(s.steal_batch_and_pop(&w2), Steal::Success(1)); assert_eq!(w2.pop(), Some(2));
Trait Implementations
impl<T> Debug for Stealer<T>
[src]
impl<T> Send for Stealer<T> where
T: Send,
[src]
T: Send,
impl<T> Clone for Stealer<T>
[src]
impl<T> Sync for Stealer<T> where
T: Send,
[src]
T: Send,
Auto Trait Implementations
impl<T> Unpin for Stealer<T>
impl<T> UnwindSafe for Stealer<T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
impl<T> RefUnwindSafe for Stealer<T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
Blanket Implementations
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> From<T> for T
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
ⓘImportant traits for &'_ mut Wfn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,