Multithread-Sicherheit der Ereignisverteilung mit Nullprüfungen
In der ereignisbasierten Programmierung ermöglichen Ereignisse die Kommunikation verschiedener Objekte und die Reaktion auf bestimmte Ereignisse. Es ist eine gängige Praxis, Ereignisse mithilfe einer Nullprüfung für den Event-Handler-Delegierten auszulösen, wie unten dargestellt:
public event EventHandler SomeEvent; ... { .... if(SomeEvent!=null)SomeEvent(); }
In Multithread-Umgebungen gibt es jedoch eine potenzielle Race-Bedingung, bei der ein anderer Thread die Aufrufliste des Ereignisses ändern könnte zwischen der Nullprüfung und dem Aufruf. Dies kann zu Ausnahmen oder falschem Verhalten führen.
Behebung des Multithread-Problems
Um dies zu mildern, wird empfohlen, den Event-Handler-Delegaten einer lokalen Variablen innerhalb des Ereignisses zuzuweisen Versandmethode, wie unten gezeigt:
protected virtual void OnSomeEvent(EventArgs args) { EventHandler ev = SomeEvent; if (ev != null) ev(this, args); }
Dadurch werden alle nachfolgenden Änderungen an der SomeEvent-Ereignishandlerliste nicht vorgenommen wirkt sich auf die in der ev-Variablen gespeicherte Kopie aus. Dadurch wird sichergestellt, dass das Ereignis korrekt aufgerufen wird, auch wenn sich die Ereignishandlerliste in der Zwischenzeit ändert.
Es ist wichtig zu beachten, dass diese Lösung nur einen Aspekt der Multithread-Ereignisbehandlung anspricht. Nicht mehr funktionierende Event-Handler oder Event-Handler, die sich nach der Erstellung der Kopie anmelden, werden nicht vollständig berücksichtigt. Einen umfassenden Leitfaden zu Best Practices in diesem Bereich finden Sie im Blogeintrag von Eric Lippert und in den StackOverflow-Diskussionen zu diesem Thema.
Das obige ist der detaillierte Inhalt vonWie kann die Multithread-Sicherheit beim Versenden von Ereignissen mit Nullprüfungen gewährleistet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!