デバッガーが接続されている場合は発生しないように見えるため、このエラーの原因を突き止めることはできません。
コレクションが変更されました。列挙操作が実行されない可能性があります
以下はコードです。
これは、Windows サービスの WCF サーバーです。このメソッドNotifySubscribers()
は、データ イベントが発生するたびにサービスによって呼び出されます (ランダムな間隔ですが、それほど頻繁ではありません - 1 日あたり約 800 回)。
Windows フォーム クライアントがサブスクライブすると、サブスクライバー ID がサブスクライバー ディクショナリに追加され、クライアントがサブスクライブを解除すると、ディクショナリから削除されます。エラーは、クライアントが登録解除したとき (またはその後) に発生します。次にNotifySubscribers()
メソッドが呼び出されると、foreach()
件名にエラーが表示されてループが失敗するようです。このメソッドは、次のコードに示すように、エラーをアプリケーション ログに書き込みます。デバッガーがアタッチされ、クライアントがサブスクライブを解除すると、コードは正常に実行されます。
このコードに問題がありますか? 辞書をスレッドセーフにする必要がありますか?
[ServiceBehavior(InstanceContextMode=InstanceContextMode.Single)]
public class SubscriptionServer : ISubscriptionServer
{
private static IDictionary<Guid, Subscriber> subscribers;
public SubscriptionServer()
{
subscribers = new Dictionary<Guid, Subscriber>();
}
public void NotifySubscribers(DataRecord sr)
{
foreach(Subscriber s in subscribers.Values)
{
try
{
s.Callback.SignalData(sr);
}
catch (Exception e)
{
DCS.WriteToApplicationLog(e.Message,
System.Diagnostics.EventLogEntryType.Error);
UnsubscribeEvent(s.ClientId);
}
}
}
public Guid SubscribeEvent(string clientDescription)
{
Subscriber subscriber = new Subscriber();
subscriber.Callback = OperationContext.Current.
GetCallbackChannel<IDCSCallback>();
subscribers.Add(subscriber.ClientId, subscriber);
return subscriber.ClientId;
}
public void UnsubscribeEvent(Guid clientId)
{
try
{
subscribers.Remove(clientId);
}
catch(Exception e)
{
System.Diagnostics.Debug.WriteLine("Unsubscribe Error " +
e.Message);
}
}
}