Trait enso_prelude::iter::ExactSizeIterator1.0.0[][src]

pub trait ExactSizeIterator: Iterator {
    fn len(&self) -> usize { ... }
fn is_empty(&self) -> bool { ... } }
Expand description

An iterator that knows its exact length.

Many Iterators don’t know how many times they will iterate, but some do. If an iterator knows how many times it can iterate, providing access to that information can be useful. For example, if you want to iterate backwards, a good start is to know where the end is.

When implementing an ExactSizeIterator, you must also implement Iterator. When doing so, the implementation of Iterator::size_hint must return the exact size of the iterator.

The len method has a default implementation, so you usually shouldn’t implement it. However, you may be able to provide a more performant implementation than the default, so overriding it in this case makes sense.

Note that this trait is a safe trait and as such does not and cannot guarantee that the returned length is correct. This means that unsafe code must not rely on the correctness of Iterator::size_hint. The unstable and unsafe TrustedLen trait gives this additional guarantee.

Examples

Basic usage:

// a finite range knows exactly how many times it will iterate
let five = 0..5;

assert_eq!(5, five.len());

In the module-level docs, we implemented an Iterator, Counter. Let’s implement ExactSizeIterator for it as well:

impl ExactSizeIterator for Counter {
    // We can easily calculate the remaining number of iterations.
    fn len(&self) -> usize {
        5 - self.count
    }
}

// And now we can use it!

let counter = Counter::new();

assert_eq!(5, counter.len());

Provided methods

fn len(&self) -> usize[src]

Returns the exact length of the iterator.

The implementation ensures that the iterator will return exactly len() more times a Some(T) value, before returning None. This method has a default implementation, so you usually should not implement it directly. However, if you can provide a more efficient implementation, you can do so. See the trait-level docs for an example.

This function has the same safety guarantees as the Iterator::size_hint function.

Examples

Basic usage:

// a finite range knows exactly how many times it will iterate
let five = 0..5;

assert_eq!(5, five.len());

fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

Returns true if the iterator is empty.

This method has a default implementation using ExactSizeIterator::len(), so you don’t need to implement it yourself.

Examples

Basic usage:

#![feature(exact_size_is_empty)]

let mut one_element = std::iter::once(0);
assert!(!one_element.is_empty());

assert_eq!(one_element.next(), Some(0));
assert!(one_element.is_empty());

assert_eq!(one_element.next(), None);

Implementations on Foreign Types

impl<'_, K> ExactSizeIterator for Drain<'_, K>[src]

pub fn len(&self) -> usize[src]

impl<'_, K, V> ExactSizeIterator for IterMut<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<'a> ExactSizeIterator for CommandEnvs<'a>[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, K, V> ExactSizeIterator for Iter<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_, K, V> ExactSizeIterator for Keys<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl ExactSizeIterator for ArgsOs[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'a> ExactSizeIterator for CommandArgs<'a>[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, K> ExactSizeIterator for Iter<'_, K>[src]

pub fn len(&self) -> usize[src]

impl<K, V> ExactSizeIterator for IntoKeys<K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_, K, V> ExactSizeIterator for Values<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl ExactSizeIterator for Args[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<K, V> ExactSizeIterator for IntoValues<K, V>[src]

pub fn len(&self) -> usize[src]

impl<K> ExactSizeIterator for IntoIter<K>[src]

pub fn len(&self) -> usize[src]

impl<'_, K, V> ExactSizeIterator for Drain<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<K, V> ExactSizeIterator for IntoIter<K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_, K, V> ExactSizeIterator for ValuesMut<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_> ExactSizeIterator for Bytes<'_>[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl ExactSizeIterator for ToUppercase[src]

impl<T, const N: usize> ExactSizeIterator for IntoIter<T, N>[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl ExactSizeIterator for EscapeDebug[src]

impl<'_, T> ExactSizeIterator for IterMut<'_, T>[src]

impl<A> ExactSizeIterator for IntoIter<A>[src]

impl<'_, I> ExactSizeIterator for &'_ mut I where
    I: ExactSizeIterator + ?Sized
[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl ExactSizeIterator for EscapeDefault[src]

impl ExactSizeIterator for EscapeDefault[src]

pub fn len(&self) -> usize[src]

impl<T> ExactSizeIterator for IntoIter<T>[src]

impl ExactSizeIterator for EscapeUnicode[src]

pub fn len(&self) -> usize[src]

impl<'a> ExactSizeIterator for EscapeAscii<'a>[src]

impl ExactSizeIterator for ToLowercase[src]

impl<'_, A> ExactSizeIterator for IterMut<'_, A>[src]

impl<'_, T> ExactSizeIterator for Iter<'_, T>[src]

impl<'_, A> ExactSizeIterator for Iter<'_, A>[src]

impl<'_, T> ExactSizeIterator for Drain<'_, T>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T> ExactSizeIterator for Iter<'_, T>[src]

pub fn len(&self) -> usize[src]

impl<'_, T> ExactSizeIterator for Drain<'_, T>[src]

impl<T> ExactSizeIterator for IntoIter<T>[src]

impl<'_, K, V> ExactSizeIterator for ValuesMut<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<I, A> ExactSizeIterator for Box<I, A> where
    I: ExactSizeIterator + ?Sized,
    A: Allocator
[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<K, V> ExactSizeIterator for IntoIter<K, V>[src]

pub fn len(&self) -> usize[src]

impl<T, A> ExactSizeIterator for IntoIter<T, A> where
    A: Allocator
[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, K, V> ExactSizeIterator for IterMut<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_, T> ExactSizeIterator for IterMut<'_, T>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T> ExactSizeIterator for IterMut<'_, T>[src]

impl<'_, T> ExactSizeIterator for Iter<'_, T>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<T> ExactSizeIterator for IntoIter<T>[src]

pub fn len(&self) -> usize[src]

impl<'_, T> ExactSizeIterator for DrainSorted<'_, T> where
    T: Ord
[src]

impl<'_, K, V> ExactSizeIterator for Iter<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<K, V> ExactSizeIterator for IntoValues<K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_, T, A> ExactSizeIterator for Drain<'_, T, A> where
    A: Allocator
[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<T> ExactSizeIterator for IntoIter<T>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, K, V> ExactSizeIterator for Keys<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_, I, A> ExactSizeIterator for Splice<'_, I, A> where
    I: Iterator,
    A: Allocator
[src]

impl<K, V> ExactSizeIterator for IntoKeys<K, V>[src]

pub fn len(&self) -> usize[src]

impl<T> ExactSizeIterator for IntoIterSorted<T> where
    T: Ord
[src]

impl<'_, T> ExactSizeIterator for Iter<'_, T>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, K, V> ExactSizeIterator for Values<'_, K, V>[src]

pub fn len(&self) -> usize[src]

impl<'_, T> ExactSizeIterator for Iter<'_, T>[src]

impl<T> ExactSizeIterator for IntoIter<T>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<A> ExactSizeIterator for IntoIter<A> where
    A: Array
[src]

impl<'a, T> ExactSizeIterator for Drain<'a, T> where
    T: Array
[src]

pub fn len(&self) -> usize[src]

impl<A, B, C, D, E, F, G, H, I, J, K, L> ExactSizeIterator for Zip<(A, B, C, D, E, F, G, H, I, J, K, L)> where
    C: ExactSizeIterator,
    F: ExactSizeIterator,
    I: ExactSizeIterator,
    K: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator,
    L: ExactSizeIterator,
    J: ExactSizeIterator,
    G: ExactSizeIterator,
    H: ExactSizeIterator
[src]

impl<A, B, C, D, E, F, G, H> ExactSizeIterator for Zip<(A, B, C, D, E, F, G, H)> where
    C: ExactSizeIterator,
    F: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator,
    G: ExactSizeIterator,
    H: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for Step<I> where
    I: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for PeekNth<I> where
    I: ExactSizeIterator
[src]

impl<A, B> ExactSizeIterator for Zip<(A, B)> where
    A: ExactSizeIterator,
    B: ExactSizeIterator
[src]

impl<A, B, C, D, E, F, G> ExactSizeIterator for Zip<(A, B, C, D, E, F, G)> where
    C: ExactSizeIterator,
    F: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator,
    G: ExactSizeIterator
[src]

impl<A, B, C, D, E, F, G, H, I> ExactSizeIterator for Zip<(A, B, C, D, E, F, G, H, I)> where
    C: ExactSizeIterator,
    F: ExactSizeIterator,
    I: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator,
    G: ExactSizeIterator,
    H: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for MultiPeek<I> where
    I: ExactSizeIterator
[src]

impl<T, U> ExactSizeIterator for ZipLongest<T, U> where
    T: ExactSizeIterator,
    U: ExactSizeIterator
[src]

impl<A, B, C, D> ExactSizeIterator for Zip<(A, B, C, D)> where
    C: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator
[src]

impl<A, B, C, D, E, F> ExactSizeIterator for Zip<(A, B, C, D, E, F)> where
    C: ExactSizeIterator,
    F: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for WithPosition<I> where
    I: ExactSizeIterator
[src]

impl<A> ExactSizeIterator for Zip<(A,)> where
    A: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for ExactlyOneError<I> where
    I: ExactSizeIterator
[src]

impl<A, B, C, D, E, F, G, H, I, J> ExactSizeIterator for Zip<(A, B, C, D, E, F, G, H, I, J)> where
    C: ExactSizeIterator,
    F: ExactSizeIterator,
    I: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator,
    J: ExactSizeIterator,
    G: ExactSizeIterator,
    H: ExactSizeIterator
[src]

impl<A, B, C, D, E, F, G, H, I, J, K> ExactSizeIterator for Zip<(A, B, C, D, E, F, G, H, I, J, K)> where
    C: ExactSizeIterator,
    F: ExactSizeIterator,
    I: ExactSizeIterator,
    K: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator,
    J: ExactSizeIterator,
    G: ExactSizeIterator,
    H: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for Tee<I> where
    I: ExactSizeIterator,
    <I as Iterator>::Item: Clone
[src]

impl<I, F> ExactSizeIterator for PadUsing<I, F> where
    F: FnMut(usize) -> <I as Iterator>::Item,
    I: ExactSizeIterator
[src]

impl<T> ExactSizeIterator for TupleBuffer<T> where
    T: HomogeneousTuple
[src]

impl<I, J> ExactSizeIterator for ZipEq<I, J> where
    I: ExactSizeIterator,
    J: ExactSizeIterator
[src]

impl<A> ExactSizeIterator for RepeatN<A> where
    A: Clone
[src]

impl<A, B, C> ExactSizeIterator for Zip<(A, B, C)> where
    C: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator
[src]

impl<A, B, C, D, E> ExactSizeIterator for Zip<(A, B, C, D, E)> where
    C: ExactSizeIterator,
    E: ExactSizeIterator,
    A: ExactSizeIterator,
    B: ExactSizeIterator,
    D: ExactSizeIterator
[src]

impl<I, F> ExactSizeIterator for Update<I, F> where
    F: FnMut(&mut <I as Iterator>::Item),
    I: ExactSizeIterator
[src]

impl<L, R> ExactSizeIterator for Either<L, R> where
    R: ExactSizeIterator<Item = <L as Iterator>::Item>,
    L: ExactSizeIterator
[src]

impl<'_> ExactSizeIterator for U32Digits<'_>[src]

pub fn len(&self) -> usize[src]

impl<'_> ExactSizeIterator for U64Digits<'_>[src]

pub fn len(&self) -> usize[src]

impl<'a> ExactSizeIterator for ArrayIter<'a>[src]

impl<'a, T, R, C, S> ExactSizeIterator for MatrixIterMut<'a, T, R, C, S> where
    C: Dim,
    T: Scalar,
    R: Dim,
    S: 'a + StorageMut<T, R, C>, 
[src]

pub fn len(&self) -> usize[src]

impl<'a, T, R, C, S> ExactSizeIterator for RowIter<'a, T, R, C, S> where
    C: Dim,
    T: Scalar,
    R: Dim,
    S: 'a + Storage<T, R, C>, 
[src]

pub fn len(&self) -> usize[src]

impl<'a, T, R, C, S> ExactSizeIterator for RowIterMut<'a, T, R, C, S> where
    C: Dim,
    T: Scalar,
    R: Dim,
    S: 'a + StorageMut<T, R, C>, 
[src]

pub fn len(&self) -> usize[src]

impl<'a, T, R, C, S> ExactSizeIterator for MatrixIter<'a, T, R, C, S> where
    C: Dim,
    T: Scalar,
    R: Dim,
    S: 'a + Storage<T, R, C>, 
[src]

pub fn len(&self) -> usize[src]

impl<'a, T, R, C, S> ExactSizeIterator for ColumnIterMut<'a, T, R, C, S> where
    C: Dim,
    T: Scalar,
    R: Dim,
    S: 'a + StorageMut<T, R, C>, 
[src]

pub fn len(&self) -> usize[src]

impl<'a, T, R, C, S> ExactSizeIterator for ColumnIter<'a, T, R, C, S> where
    C: Dim,
    T: Scalar,
    R: Dim,
    S: 'a + Storage<T, R, C>, 
[src]

pub fn len(&self) -> usize[src]

Implementors

impl ExactSizeIterator for Range<i8>[src]

impl ExactSizeIterator for Range<i16>[src]

impl ExactSizeIterator for Range<i32>[src]

impl ExactSizeIterator for Range<isize>[src]

impl ExactSizeIterator for Range<u8>[src]

impl ExactSizeIterator for Range<u16>[src]

impl ExactSizeIterator for Range<u32>[src]

impl ExactSizeIterator for Range<usize>[src]

impl ExactSizeIterator for RangeInclusive<i8>1.26.0[src]

impl ExactSizeIterator for RangeInclusive<i16>1.26.0[src]

impl ExactSizeIterator for RangeInclusive<u8>1.26.0[src]

impl ExactSizeIterator for RangeInclusive<u16>1.26.0[src]

impl<'_, T> ExactSizeIterator for Chunks<'_, T>[src]

impl<'_, T> ExactSizeIterator for ChunksExact<'_, T>1.31.0[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T> ExactSizeIterator for ChunksExactMut<'_, T>1.31.0[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T> ExactSizeIterator for ChunksMut<'_, T>[src]

impl<'_, T> ExactSizeIterator for enso_prelude::slice::Iter<'_, T>[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T> ExactSizeIterator for enso_prelude::slice::IterMut<'_, T>[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T> ExactSizeIterator for RChunks<'_, T>1.31.0[src]

impl<'_, T> ExactSizeIterator for RChunksExactMut<'_, T>1.31.0[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T> ExactSizeIterator for RChunksMut<'_, T>1.31.0[src]

impl<'_, T> ExactSizeIterator for Windows<'_, T>[src]

impl<'_, T, const N: usize> ExactSizeIterator for ArrayChunks<'_, T, N>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T, const N: usize> ExactSizeIterator for ArrayChunksMut<'_, T, N>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'_, T, const N: usize> ExactSizeIterator for ArrayWindows<'_, T, N>[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'a, I, T> ExactSizeIterator for Cloned<I> where
    T: 'a + Clone,
    I: ExactSizeIterator<Item = &'a T>, 
1.1.0[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'a, I, T> ExactSizeIterator for Copied<I> where
    T: 'a + Copy,
    I: ExactSizeIterator<Item = &'a T>, 
1.36.0[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<'a, T> ExactSizeIterator for RChunksExact<'a, T>1.31.0[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<A, B> ExactSizeIterator for enso_prelude::iter::Zip<A, B> where
    A: ExactSizeIterator,
    B: ExactSizeIterator
[src]

impl<A, F> ExactSizeIterator for OnceWith<F> where
    F: FnOnce() -> A, 
1.43.0[src]

pub fn len(&self) -> usize[src]

impl<B, I, F> ExactSizeIterator for Map<I, F> where
    F: FnMut(<I as Iterator>::Item) -> B,
    I: ExactSizeIterator
[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<I> ExactSizeIterator for Enumerate<I> where
    I: ExactSizeIterator
[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<I> ExactSizeIterator for Fuse<I> where
    I: ExactSizeIterator
[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<I> ExactSizeIterator for Peekable<I> where
    I: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for Rev<I> where
    I: ExactSizeIterator + DoubleEndedIterator
[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<I> ExactSizeIterator for Skip<I> where
    I: ExactSizeIterator
[src]

impl<I> ExactSizeIterator for StepBy<I> where
    I: ExactSizeIterator
1.28.0[src]

impl<I> ExactSizeIterator for Take<I> where
    I: ExactSizeIterator
[src]

impl<I, F> ExactSizeIterator for Inspect<I, F> where
    F: FnMut(&<I as Iterator>::Item),
    I: ExactSizeIterator
[src]

pub fn len(&self) -> usize[src]

pub fn is_empty(&self) -> bool[src]

🔬 This is a nightly-only experimental API. (exact_size_is_empty)

impl<T> ExactSizeIterator for Empty<T>1.2.0[src]

pub fn len(&self) -> usize[src]

impl<T> ExactSizeIterator for Once<T>1.2.0[src]

pub fn len(&self) -> usize[src]