pub struct ConIterSlice<'a, T> { /* private fields */ }Expand description
Concurrent iterator of a slice.
It can be created by calling into_con_iter on a slice.
Alternatively, it can be created calling con_iter on the type
that owns the slice.
§Examples
use orx_concurrent_iter::*;
// &[T]: IntoConcurrentIter
let vec = vec![0, 1, 2, 3];
let slice = &vec[1..3];
let con_iter = slice.into_con_iter();
assert_eq!(con_iter.next(), Some(&1));
assert_eq!(con_iter.next(), Some(&2));
assert_eq!(con_iter.next(), None);
// Vec<T>: ConcurrentIterable
let vec = vec![1, 2];
let con_iter = vec.con_iter();
assert_eq!(con_iter.next(), Some(&1));
assert_eq!(con_iter.next(), Some(&2));
assert_eq!(con_iter.next(), None);Trait Implementations§
Source§impl<T> Clone for ConIterSlice<'_, T>where
    T: Sync,
 
impl<T> Clone for ConIterSlice<'_, T>where
    T: Sync,
Source§impl<'a, T> ConcurrentIter for ConIterSlice<'a, T>where
    T: Sync,
 
impl<'a, T> ConcurrentIter for ConIterSlice<'a, T>where
    T: Sync,
Source§type SequentialIter = Skip<Iter<'a, T>>
 
type SequentialIter = Skip<Iter<'a, T>>
Type of the sequential iterator that the concurrent iterator can be converted
into using the 
into_seq_iter method.Source§type ChunkPuller<'i> = ChunkPullerSlice<'i, 'a, T>
where
    Self: 'i
 
type ChunkPuller<'i> = ChunkPullerSlice<'i, 'a, T> where Self: 'i
Type of the chunk puller that can be created using the 
chunk_puller method.Source§fn into_seq_iter(self) -> Self::SequentialIter
 
fn into_seq_iter(self) -> Self::SequentialIter
Converts the concurrent iterator into its sequential regular counterpart.
Note that the sequential iterator is a regular 
Iterator, and hence,
does not have any overhead related with atomic states. Therefore, it is
useful where the program decides to iterate over a single thread rather
than concurrently by multiple threads. Read moreSource§fn skip_to_end(&self)
 
fn skip_to_end(&self)
Immediately jumps to the end of the iterator, skipping the remaining elements. Read more
Source§fn next(&self) -> Option<Self::Item>
 
fn next(&self) -> Option<Self::Item>
Returns the next element of the iterator.
It returns None if there are no more elements left. Read more
Source§fn next_with_idx(&self) -> Option<(usize, Self::Item)>
 
fn next_with_idx(&self) -> Option<(usize, Self::Item)>
Returns the next element of the iterator together its index.
It returns None if there are no more elements left. Read more
Source§fn size_hint(&self) -> (usize, Option<usize>)
 
fn size_hint(&self) -> (usize, Option<usize>)
Returns the bounds on the remaining length of the iterator. Read more
Source§fn is_completed_when_none_returned(&self) -> bool
 
fn is_completed_when_none_returned(&self) -> bool
Source§fn chunk_puller(&self, chunk_size: usize) -> Self::ChunkPuller<'_>
 
fn chunk_puller(&self, chunk_size: usize) -> Self::ChunkPuller<'_>
Creates a 
ChunkPuller from the concurrent iterator.
The created chunk puller can be used to pull chunk_size elements at once from the
data source, rather than pulling one by one. Read moreSource§fn try_get_len(&self) -> Option<usize>
 
fn try_get_len(&self) -> Option<usize>
Returns 
Some(x) if the number of remaining items is known with certainly and if it
is equal to x. Read moreSource§fn item_puller(&self) -> ItemPuller<'_, Self> ⓘwhere
    Self: Sized,
 
fn item_puller(&self) -> ItemPuller<'_, Self> ⓘwhere
    Self: Sized,
Creates a 
ItemPuller from the concurrent iterator.
The created item puller can be used to pull elements one by one from the
data source. Read moreSource§fn item_puller_with_idx(&self) -> EnumeratedItemPuller<'_, Self> ⓘwhere
    Self: Sized,
 
fn item_puller_with_idx(&self) -> EnumeratedItemPuller<'_, Self> ⓘwhere
    Self: Sized,
Creates a 
EnumeratedItemPuller from the concurrent iterator.
The created item puller can be used to pull elements one by one from the
data source together with the index of the elements. Read moreSource§fn copied<'a, T>(self) -> ConIterCopied<'a, Self, T>
 
fn copied<'a, T>(self) -> ConIterCopied<'a, Self, T>
Creates an iterator which copies all of its elements. Read more
Source§fn cloned<'a, T>(self) -> ConIterCloned<'a, Self, T>
 
fn cloned<'a, T>(self) -> ConIterCloned<'a, Self, T>
Creates an iterator which clones all of its elements. Read more
Source§fn enumerate(self) -> Enumerate<Self>where
    Self: Sized,
 
fn enumerate(self) -> Enumerate<Self>where
    Self: Sized,
Creates an iterator which gives the current iteration count as well as the next value. Read more
Source§fn chain_inexact<C>(self, other: C) -> ChainUnknownLenI<Self, C::IntoIter>
 
fn chain_inexact<C>(self, other: C) -> ChainUnknownLenI<Self, C::IntoIter>
Creates a chain of this and 
other concurrent iterators. Read moreSource§impl<T> Debug for ConIterSlice<'_, T>where
    T: Sync,
 
impl<T> Debug for ConIterSlice<'_, T>where
    T: Sync,
Source§impl<T> Default for ConIterSlice<'_, T>
 
impl<T> Default for ConIterSlice<'_, T>
Source§impl<T> ExactSizeConcurrentIter for ConIterSlice<'_, T>where
    T: Sync,
 
impl<T> ExactSizeConcurrentIter for ConIterSlice<'_, T>where
    T: Sync,
Source§fn len(&self) -> usize
 
fn len(&self) -> usize
Returns the number remaining elements in the concurrent iterator. Read more
Source§fn is_empty(&self) -> bool
 
fn is_empty(&self) -> bool
Returns true if there are no elements left in the concurrent iterator.
Returns false otherwise. Read more
Auto Trait Implementations§
impl<'a, T> !Freeze for ConIterSlice<'a, T>
impl<'a, T> RefUnwindSafe for ConIterSlice<'a, T>where
    T: RefUnwindSafe,
impl<'a, T> Send for ConIterSlice<'a, T>where
    T: Sync,
impl<'a, T> Sync for ConIterSlice<'a, T>where
    T: Sync,
impl<'a, T> Unpin for ConIterSlice<'a, T>
impl<'a, T> UnwindSafe for ConIterSlice<'a, T>where
    T: RefUnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
Source§impl<I> IntoConcurrentIter for Iwhere
    I: ConcurrentIter,
 
impl<I> IntoConcurrentIter for Iwhere
    I: ConcurrentIter,
Source§type Item = <I as ConcurrentIter>::Item
 
type Item = <I as ConcurrentIter>::Item
Type of the element that the concurrent iterator yields.
Source§fn into_con_iter(self) -> <I as IntoConcurrentIter>::IntoIter
 
fn into_con_iter(self) -> <I as IntoConcurrentIter>::IntoIter
Trait to convert a source (collection or generator) into a concurrent iterator; i.e., 
ConcurrentIter,
using its into_con_iter method. Read more