These are different ways to loop over a collection:
- do()
- do/while()
- for()
- foreach()
- ForEach()
- For()
- For(MaxDegreeOfParallelism)
- ForEach()
- ForEach(MaxDegreeOfParallelism)
- ForEachAsync()
- ForEachAsync(MaxDegreeOfParallelism)
Which one of these ways to loop over a collection do you think is the fastest? First, let’s look at a few of these ways to loop over an array. This is an example of using Parallel.For() with MaxDegreeOfParallelism:
Benchmark Results
Here are the benchmark results that shows using Parallel.For() for a reference, value and record type.
Here is an example of using Parallel.ForEachAsync().
Benchmark Results
Here are the benchmark results that shows using Parallel.ForEachAsync() for a reference, value and record type.
As you can see from these benchmarks, using Parallel.ForEachAsync() is a lot slower than using Parallel.For() (around 6.86 times slower).
So, what is the fastest way to loop over an array? Well, according to my benchmark tests, it can actually vary depending on the type used in the array. If the array contains a reference or value type, then using for() is the clear winner! If the array contains the record type, then using Parallel.For() is the fastest (around 1.13 times faster) Here is an example:
In all of my benchmark tests, value types (structures) loops the slowest when compared to the reference and record type. I recommend to not use them in collections.
Using Spargine to Speed Up Arrays
I am currently making changes to my OSS project Spargine based on the findings in the latest edition of my code performance book. To make processing collections as fast as possible easy, I’m adding extension methods called PerformAction(). Here is how I unit test this method:
This method also verifies there are items in the array to prevent exceptions. I will be using this method from now on when processing arrays because if the .NET team comes out with an even faster way to loop over an array, I can just change the code in PerformAction() and instantly all projects that use it get the performance boost! Code reuse is a good thing! I will revisit these methods whenever I do a major run of my benchmark tests so make sure to keep the Spargine NuGet packages up to date. You can add Spargine to your projects by going here: http://bit.ly/dotNetDaveNuGet.
No comments:
Post a Comment