Struct orx_concurrent_iter::ConIterOfIter

source ·
pub struct ConIterOfIter<T: Send + Sync, Iter>
where Iter: Iterator<Item = T>,
{ /* private fields */ }
Expand description

A regular Iter: Iterator ascended to the concurrent programs with use of atomics.

Since ConIterOfIter can wrap up any Iterator and enable concurrent iteration, it might be considered as the most general ConcurrentIter implementation.

In performance critical scenarios and whenever possible, it might be preferable to use a more specific implementation such as crate::ConIterOfSlice.

Implementations§

source§

impl<T: Send + Sync, Iter> ConIterOfIter<T, Iter>
where Iter: Iterator<Item = T>,

source

pub fn new(iter: Iter) -> Self

Creates a concurrent iterator for the given iter.

Trait Implementations§

source§

impl<T: Send + Sync, Iter> AtomicIter for ConIterOfIter<T, Iter>
where Iter: Iterator<Item = T>,

§

type Item = T

Type of the items that the iterator yields.
source§

fn counter(&self) -> &AtomicCounter

Returns a reference to the underlying advanced item counter.
source§

fn get(&self, item_idx: usize) -> Option<Self::Item>

Returns the item_idx-th item that the iterator yields; returns None if the iterator completes before.
source§

fn fetch_n(&self, n: usize) -> impl NextChunk<Self::Item>

Returns an iterator of the next n consecutive items that the iterator yields. It might return an iterator of less or no items if the iteration does not have sufficient elements left.
source§

fn fetch_one(&self) -> Option<Next<Self::Item>>

Returns the next item that the iterator yields; returns None if the iteration has completed.
source§

impl<T: Debug + Send + Sync, Iter> Debug for ConIterOfIter<T, Iter>
where Iter: Iterator<Item = T> + Debug,

source§

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

Formats the value using the given formatter. Read more
source§

impl<T: Send + Sync, Iter> From<Iter> for ConIterOfIter<T, Iter>
where Iter: Iterator<Item = T>,

source§

fn from(iter: Iter) -> Self

Converts to this type from the input type.
source§

impl<T: Send + Sync, Iter> Send for ConIterOfIter<T, Iter>
where Iter: Iterator<Item = T>,

source§

impl<T: Send + Sync, Iter> Sync for ConIterOfIter<T, Iter>
where Iter: Iterator<Item = T>,

Auto Trait Implementations§

§

impl<T, Iter> !Freeze for ConIterOfIter<T, Iter>

§

impl<T, Iter> !RefUnwindSafe for ConIterOfIter<T, Iter>

§

impl<T, Iter> Unpin for ConIterOfIter<T, Iter>
where Iter: Unpin,

§

impl<T, Iter> UnwindSafe for ConIterOfIter<T, Iter>
where Iter: UnwindSafe,

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<A> ConcurrentIter for A
where A: AtomicIter,

§

type Item = <A as AtomicIter>::Item

Type of the items that the iterator yields.
source§

fn next_id_and_value(&self) -> Option<Next<<A as AtomicIter>::Item>>

Advances the iterator and returns the next value together with its enumeration index. Read more
source§

fn next_chunk(&self, n: usize) -> impl NextChunk<<A as AtomicIter>::Item>

Advances the iterator chunk_size times and returns an iterator of at most chunk_size consecutive next values. Further, the beginning enumeration index of the yielded values is returned. Read more
source§

fn next(&self) -> Option<Self::Item>

Advances the iterator and returns the next value. Read more
source§

fn values(&self) -> ConIterValues<'_, Self>
where Self: Sized,

Returns an Iterator over the values of elements of the concurrent iterator. Read more
source§

fn ids_and_values(&self) -> ConIterIdsAndValues<'_, Self>
where Self: Sized,

Returns an Iterator over the ids and values of elements of the concurrent iterator. 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 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, U> TryFrom<U> for T
where 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 T
where 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.