-
Notifications
You must be signed in to change notification settings - Fork 274
/
Copy pathIterateForEachNonGeneric.cs
90 lines (77 loc) · 2.91 KB
/
IterateForEachNonGeneric.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
using BenchmarkDotNet.Attributes;
using BenchmarkDotNet.Extensions;
using MicroBenchmarks;
namespace System.Collections
{
[BenchmarkCategory(Categories.Libraries, Categories.Collections, Categories.NonGenericCollections)]
[GenericTypeArguments(typeof(int))] // value type (it shows how bad idea is to use non-generic collections for value types)
[GenericTypeArguments(typeof(string))] // reference type
public class IterateForEachNonGeneric<T>
{
[Params(Utils.DefaultCollectionSize)]
public int Size;
private ArrayList _arraylist;
private Hashtable _hashtable;
private Queue _queue;
private Stack _stack;
private SortedList _sortedlist;
[GlobalSetup(Target = nameof(ArrayList))]
public void SetupArrayList() => _arraylist = new ArrayList(ValuesGenerator.ArrayOfUniqueValues<T>(Size));
[Benchmark]
public object ArrayList()
{
object result = default;
var collection = _arraylist;
foreach(var item in collection)
result = item;
return result;
}
[GlobalSetup(Target = nameof(Hashtable))]
public void SetupHashtable() => _hashtable = new Hashtable(ValuesGenerator.Dictionary<T, T>(Size));
[Benchmark]
public object Hashtable()
{
object result = default;
var collection = _hashtable;
foreach(var item in collection)
result = item;
return result;
}
[GlobalSetup(Target = nameof(Queue))]
public void SetupQueue() => _queue = new Queue(ValuesGenerator.ArrayOfUniqueValues<T>(Size));
[Benchmark]
public object Queue()
{
object result = default;
var collection = _queue;
foreach(var item in collection)
result = item;
return result;
}
[GlobalSetup(Target = nameof(Stack))]
public void SetupStack() => _stack = new Stack(ValuesGenerator.ArrayOfUniqueValues<T>(Size));
[Benchmark]
public object Stack()
{
object result = default;
var collection = _stack;
foreach(var item in collection)
result = item;
return result;
}
[GlobalSetup(Target = nameof(SortedList))]
public void SetupSortedList() => _sortedlist = new SortedList(ValuesGenerator.Dictionary<T, T>(Size));
[Benchmark]
public object SortedList()
{
object result = default;
var collection = _sortedlist;
foreach(var item in collection)
result = item;
return result;
}
}
}