Struct crossbeam_deque::Stealer
source · [−]pub struct Stealer<T> { /* private fields */ }
Expand description
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);
Implementations
sourceimpl<T> Stealer<T>
impl<T> Stealer<T>
sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
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());
sourcepub fn steal(&self) -> Steal<T>
pub fn steal(&self) -> Steal<T>
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));
sourcepub fn steal_batch(&self, dest: &Worker<T>) -> Steal<()>
pub fn steal_batch(&self, dest: &Worker<T>) -> Steal<()>
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));
sourcepub fn steal_batch_and_pop(&self, dest: &Worker<T>) -> Steal<T>
pub fn steal_batch_and_pop(&self, dest: &Worker<T>) -> Steal<T>
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: Send> Send for Stealer<T>
impl<T: Send> Sync for Stealer<T>
Auto Trait Implementations
impl<T> RefUnwindSafe for Stealer<T> where
T: RefUnwindSafe,
impl<T> Unpin for Stealer<T>
impl<T> UnwindSafe for Stealer<T> where
T: RefUnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcepub fn to_owned(&self) -> T
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
sourcepub fn clone_into(&self, target: &mut T)
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more