Suppose following code:
if (myDictionary.ContainsKey(aKey))
myDictionary[aKey] = aValue;
else
myDictionary.Add(aKey, aValue);
This code accesses the dictionary two times, once for determining whether aKey
exist, another time for updating (if exist) or adding (if does not exist). I guess the performance of this method is "acceptable" when this code is executed for only few times. However, in my application similar code is executed roughly 500K times. I profiled my code, and it shows 80% of CPU time spent on this section (see following figure), so this motivates an improvement.
Note that, the dictionary is lambdas
.
First workaround is simply:
myDictionary[aKey] = aValue;
If aKey
exist it's value is replaced with aValue
; if does not exist, a KeyValuePair
with aKey
as key and aValue
as value is added to myDictionary
. However, this method has two drawbacks:
First, you don't know if aKey
exist or not that prevents you from additional logics. For instance, you can not rewrite following code based on this workaround:
int addCounter = 0, updateCounter = 0;
if (myDictionary.ContainsKey(aKey))
{
myDictionary[aKey] = aValue;
addCounter++;
}
else
{
myDictionary.Add(aKey, aValue);
updateCounter++;
}
Second, the update can not be a function of the old value. For instance, you can not do a logic similar to:
if (myDictionary.ContainsKey(aKey))
myDictionary[aKey] = (myDictionary[aKey] * 2) + aValue;
else
myDictionary.Add(aKey, aValue);
Second workaround is to use ConcurrentDictionary
. It's clear that using delegates
we can solve the second aforementioned issue; however, still it is not clear to me how we can address the first issue.
Just to remind, my concern is to speed-up. Given that there is only one thread using this procedure, I don't think the penalty of concurrency (with locks) for only one thread worth using ConcurrentDictionary
.
Am I missing a point ? does anyone has a better suggestion ?