MoreEnumerableBatchTSource, TResult(IEnumerableTSource, Int32, FuncTSource, TResult) Method

Batches the source sequence into sized buckets and applies a projection to each bucket.

Definition

Namespace: MoreLinq
Assembly: MoreLinq (in MoreLinq.dll) Version: 4.4.0+6d97c3b1d482f98300f4446df14742b0e3fafbec
C#
public static IEnumerable<TResult> Batch<TSource, TResult>(
	this IEnumerable<TSource> source,
	int size,
	Func<TSource[], TResult> resultSelector
)

Parameters

source  IEnumerableTSource
The source sequence.
size  Int32
Size of buckets.
resultSelector  FuncTSource, TResult
The projection to apply to each bucket.

Type Parameters

TSource
Type of elements in source sequence.
TResult
Type of result returned by resultSelector.

Return Value

IEnumerableTResult
A sequence of projections on equally sized buckets containing elements of the source collection.

Usage Note

In Visual Basic and C#, you can call this method as an instance method on any object of type IEnumerableTSource. When you use instance method syntax to call this method, omit the first parameter. For more information, see Extension Methods (Visual Basic) or Extension Methods (C# Programming Guide).

Remarks

This operator uses deferred execution and streams its results (buckets are streamed but their content buffered).

When more than one bucket is streamed, all buckets except the last is guaranteed to have size elements. The last bucket may be smaller depending on the remaining elements in the source sequence.

Each bucket is pre-allocated to size elements. If size is set to a very large value, e.g. MaxValue to effectively disable batching by just hoping for a single bucket, then it can lead to memory exhaustion (OutOfMemoryException).

See Also