I’m trying to make my application thread safe. I hold my hands up and admit I’m new to threading so not sure what way to proceed.
To give a simplified version, my application contains a list.
- Most of the application accesses this list and doesn’t change it but
may enumerate through it. All this happens on the UI thread. - Thread
one will periodically look for items to be Added and Removed from the
list. - Thread two will enumerate the list and update the items with
extra information. This has to run at the same time as thread one as
can take anything from seconds to hours.
The first question is does anyone have a recommend stragy for this.
Secondly I was trying to make seperate copies of the list that the main application will use, periodically getting a new copy when something is updated/added or removed, but this doesn’t seem to be working.
I have my list and a copy……
public class MDGlobalObjects
{
public List<T> mainList= new List<T>();
public List<T> copyList
{
get
{
return new List<T>(mainList);
}
}
}
If I get copyList, modify it, save mainlist, restart my application, load mainlist and look again at copylist then the changes are present. I presume I’ve done something wrong as copylist seems to still refer to mainlist.
I’m not sure if it makes a difference but everything is accessed through a static instance of the class.
public static MDGlobalObjects CacheObjects = new MDGlobalObjects();
This is the gist using a ConcurrentDictionary:
In thread 2, if you can set properties so that the whole object is consistent after each atomic write, then you can skip making a copy and just populate the properties with the object in place in the collection.
There are a few race conditions in this code, but they should be benign in that readers always have a consistent view of the collection.