pub struct GroupBy<K, I, F>where
I: Iterator,{ /* private fields */ }
Expand description
GroupBy
is the storage for the lazy grouping operation.
If the groups are consumed in their original order, or if each
group is dropped without keeping it around, then GroupBy
uses
no allocations. It needs allocations only if several group iterators
are alive at the same time.
This type implements IntoIterator
(it is not an iterator
itself), because the group iterators need to borrow from this
value. It should be stored in a local variable or temporary and
iterated.
See .group_by()
for more information.
Trait Implementations§
Source§impl<'a, K, I, F> IntoIterator for &'a GroupBy<K, I, F>
impl<'a, K, I, F> IntoIterator for &'a GroupBy<K, I, F>
Auto Trait Implementations§
impl<K, I, F> !Freeze for GroupBy<K, I, F>
impl<K, I, F> !RefUnwindSafe for GroupBy<K, I, F>
impl<K, I, F> Send for GroupBy<K, I, F>
impl<K, I, F> !Sync for GroupBy<K, I, F>
impl<K, I, F> Unpin for GroupBy<K, I, F>
impl<K, I, F> UnwindSafe for GroupBy<K, I, F>where
F: UnwindSafe,
I: UnwindSafe,
K: UnwindSafe,
<I as Iterator>::Item: UnwindSafe + 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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreLayout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.