NetFabric.ForEachEx
2.0.0
Prefix Reserved
dotnet add package NetFabric.ForEachEx --version 2.0.0
NuGet\Install-Package NetFabric.ForEachEx -Version 2.0.0
<PackageReference Include="NetFabric.ForEachEx" Version="2.0.0" />
paket add NetFabric.ForEachEx --version 2.0.0
#r "nuget: NetFabric.ForEachEx, 2.0.0"
// Install NetFabric.ForEachEx as a Cake Addin #addin nuget:?package=NetFabric.ForEachEx&version=2.0.0 // Install NetFabric.ForEachEx as a Cake Tool #tool nuget:?package=NetFabric.ForEachEx&version=2.0.0
NetFabric.ForEachEx
Overview
The NetFabric.ForEachEx package is a valuable addition to your .NET projects that enhances the functionality of the ForEach
method, specifically designed for enumerables. With this package, you can seamlessly apply the ForEachEx
method to various enumerable types, making your code cleaner, more concise, and more efficient.
Features
Universal
ForEachEx
: Apply theForEachEx
method to a wide range of enumerable types, including lists, arrays, spans, and more, simplifying your iteration code.Improved Readability: Simplify your code by using a consistent
ForEachEx
syntax across different enumerable types, making it more readable and maintainable.Custom Value Actions: Easily create custom value actions to perform operations on enumerable elements efficiently, all while avoiding heap allocations.
Vectorization (SIMD) support: Take advantage of vectorization (SIMD) support using
ForEachVectorEx
to improve the performance of your code.
Installation
You can easily add the NetFabric.ForEachEx package to your .NET project using NuGet Package Manager. Simply run the following command in your project directory:
dotnet add package NetFabric.ForEachEx
Usage
Using NetFabric.ForEachEx is straightforward. First, ensure you've added the package to your project as described in the installation section.
Then, you can import the NetFabric
namespace and start using the enhanced ForEachEx
method with various enumerable types:
using NetFabric;
// ...
var myList = new List<int> { 1, 2, 3, 4, 5 };
myList.ForEachEx(item => Console.WriteLine(item));
The ForEachEx
method is now available for enumerable types, allowing you to iterate through and operate on their elements with ease.
Additionally, you can take advantage of custom value actions to perform specific operations on enumerable elements. Here's an example of how to create and use a custom value action:
using NetFabric;
// Define a custom value action
public struct CustomValueAction<T> : IAction<T>
{
private int count;
public CustomValueAction(int initialCount)
{
count = initialCount;
}
public void Invoke(T item)
{
// Implement your custom action here
Console.WriteLine($"Item {count}: {item}");
count++;
}
}
// ...
var values = new List<int> { 10, 20, 30, 40, 50 };
var customAction = new CustomValueAction<int>(1);
values.ForEachEx(customAction); // Apply the custom action to the enumerable
In this example, the CustomValueAction<T>
struct is implemented to perform a custom action on each element of the values
enumerable. You can define your logic inside the Invoke
method of your custom value action.
You can also take advantage of vectorization (SIMD) support using the ForEachVectorEx
method. Here's an example using the provided SumValueAction
to summ all the items of the collection:
using NetFabric;
// ...
var myList = new List<int> { 1, 2, 3, 4, 5 };
var action = new SumValueAction<int>();
myList.ForEachVectorEx(action);
var sum = action.Result;
You can find how to implement a value action that support vectorization by checking the source code of the SumValueAction
class.
With the NetFabric.ForEachEx package, you can easily apply the ForEachEx
method to various enumerable types while also benefiting from the fact that value actions do not allocate on the heap, unlike lambda expressions. This can lead to improved memory efficiency in your code.
Benchmarks
The latest benchmarks for the NetFabric.ForEachEx package can be found in BENCHMARKS.md.
Contribution
Contributions are welcome! If you encounter issues or have suggestions for improvements, please feel free to open an issue or submit a pull request on our GitHub repository.
License
This package is licensed under the MIT License. See the LICENSE file for details.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 is compatible. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Changed Invoke() in IAction to take a ref T parameter.
Add support for vectorization (SIMD).