私はいくつかの同期構造をテストしていましたが、混乱することに気付きました。同時に書き込み中にコレクションを列挙していると、例外がスローされましたが (これは予期されていました)、for ループを使用してコレクションをループすると、そうではありませんでした。誰かがこれを説明できますか?リストでは、リーダーとライターが同時に操作することはできないと思いました。コレクションをループすると、列挙子を使用した場合と同じ動作を示すと予想していました。
更新: これは純粋に学術的な演習です。リストが同時に書き込まれている場合、リストを列挙するのは悪いことだと理解しています。また、同期構造が必要であることも理解しています。私の質問は、操作 1 では期待どおりに例外がスローされるのに、もう 1 つは例外がスローされない理由についてです。
コードは以下のとおりです。
class Program
{
private static List<string> _collection = new List<string>();
static void Main(string[] args)
{
ThreadPool.QueueUserWorkItem(new WaitCallback(AddItems), null);
System.Threading.Thread.Sleep(5000);
ThreadPool.QueueUserWorkItem(new WaitCallback(DisplayItems), null);
Console.ReadLine();
}
public static void AddItems(object state_)
{
for (int i = 1; i <= 50; i++)
{
_collection.Add(i.ToString());
Console.WriteLine("Adding " + i);
System.Threading.Thread.Sleep(150);
}
}
public static void DisplayItems(object state_)
{
// This will not throw an exception
//for (int i = 0; i < _collection.Count; i++)
//{
// Console.WriteLine("Reading " + _collection[i]);
// System.Threading.Thread.Sleep(150);
//}
// This will throw an exception
List<string>.Enumerator enumerator = _collection.GetEnumerator();
while (enumerator.MoveNext())
{
string value = enumerator.Current;
System.Threading.Thread.Sleep(150);
Console.WriteLine("Reading " + value);
}
}
}