Trait TrustedLen
unsafe trait TrustedLen: Iterator
An iterator that reports an accurate length using size_hint.
The iterator reports a size hint where it is either exact
(lower bound is equal to upper bound), or the upper bound is None.
The upper bound must only be None if the actual iterator length is
larger than usize::MAX. In that case, the lower bound must be
usize::MAX, resulting in an [Iterator::size_hint()] of
(usize::MAX, None).
The iterator must produce exactly the number of elements it reported or diverge before reaching the end.
When shouldn't an adapter be TrustedLen?
If an adapter makes an iterator shorter by a given amount, then it's
usually incorrect for that adapter to implement TrustedLen. The inner
iterator might return more than usize::MAX items, but there's no way to
know what k elements less than that will be, since the size_hint from
the inner iterator has already saturated and lost that information.
This is why Skip<I> isn't TrustedLen, even when
I implements TrustedLen.
Safety
This trait must only be implemented when the contract is upheld. Consumers
of this trait must inspect [Iterator::size_hint()]’s upper bound.
Implementors
impl<I> TrustedLen for StepBy<I>impl<T> TrustedLen for Empty<T>impl<T> TrustedLen for ChunksMut<'_, T>impl<A> TrustedLen for IterMut<'_, A>impl<T> TrustedLen for Once<T>impl<I> TrustedLen for Rev<I>impl<I> TrustedLen for Enumerate<I>impl<T> TrustedLen for ChunksExact<'_, T>impl TrustedLen for ToUppercaseimpl<A, F: FnOnce() -> A> TrustedLen for OnceWith<F>impl<A, B> TrustedLen for Chain<A, B>impl<A> TrustedLen for IntoIter<A>impl<I> TrustedLen for Peekable<I>impl<I> TrustedLen for Fuse<I>impl<T> TrustedLen for ChunksExactMut<'_, T>impl<A: TrustedLen> TrustedLen for OptionFlatten<A>impl<'a, I, T> TrustedLen for Copied<I>impl<T, N: usize> TrustedLen for ArrayWindows<'_, T, N>impl<A: TrustedStep> TrustedLen for RangeIter<A>impl<T> TrustedLen for RChunks<'_, T>impl<A: TrustedStep> TrustedLen for RangeInclusiveIter<A>impl<A: TrustedStep> TrustedLen for RangeInclusive<A>impl<I> TrustedLen for Flatten<I>impl<T> TrustedLen for RChunksMut<'_, T>impl<A: TrustedStep> TrustedLen for RangeFrom<A>impl<T, N: usize> TrustedLen for IntoIter<T, N>impl<A: TrustedStep> TrustedLen for Range<A>impl<A: TrustedStep> TrustedLen for RangeFromIter<A>impl<'a, I, T> TrustedLen for Cloned<I>impl<A, B> TrustedLen for Zip<A, B>impl<T> TrustedLen for RChunksExact<'_, T>impl<A> TrustedLen for Iter<'_, A>impl<A: Clone> TrustedLen for Repeat<A>impl TrustedLen for ToLowercaseimpl<T> TrustedLen for RChunksExactMut<'_, T>impl<A> TrustedLen for IterMut<'_, A>impl<A, F: FnMut() -> A> TrustedLen for RepeatWith<F>impl<I> TrustedLen for Skip<I>impl TrustedLen for Bytes<'_>impl<B, I, F> TrustedLen for Map<I, F>impl<I: TrustedLen> TrustedLen for Take<I>impl<A> TrustedLen for IntoIter<A>impl<T> TrustedLen for Iter<'_, T>impl<T> TrustedLen for IterMut<'_, T>impl<T> TrustedLen for Windows<'_, T>impl<I: TrustedLen + ?Sized> TrustedLen for &mut Iimpl<A: Clone> TrustedLen for RepeatN<A>impl<T> TrustedLen for Chunks<'_, T>impl<I, U, F> TrustedLen for FlatMap<I, U, F>impl<A> TrustedLen for Iter<'_, A>