Heim >Backend-Entwicklung >C++ >Warum bleibt meine asynchrone C#-Aktion hängen, wenn ich auf die Ergebniseigenschaft der Aufgabe zugreife?
Asynchroner C#-Vorgang in der Task.Result-Eigenschaft blockiert: Ausführliche Erklärung zum Deadlock
Asynchrone Programmierung mit den Schlüsselwörtern „async“ und „await“ von C# kann manchmal zu verwirrendem Verhalten führen. Dieser Artikel befasst sich mit einem Szenario, in dem ein asynchroner Vorgang an der Result-Eigenschaft einer Aufgabe stoppt.
Problembeschreibung
Der Entwickler stieß auf dieses Problem in einer klassischen dreischichtigen Anwendung, die eine asynchrone Methode zum Abrufen von Daten verwendete. Die ExecuteAsync
-Methode startet die SQL-Operation für den Thread-Pool-Thread und die nachfolgende Methode GetTotalAsync
verwendet „await“, um auf die Ergebnisse zuzugreifen. Wenn die UI-Methode jedoch auf die Result-Eigenschaft der asynchronen Aufgabe zugreift, friert die Anwendung ein.
Grundursache: Deadlock
Die Ursache des Problems liegt in einem häufigen Fehler bei der Verwendung der Task Parallel Library (TPL). Standardmäßig plant die Laufzeit eine Fortsetzung einer Funktion auf demselben SynchronizationContext, der die Methode ursprünglich gestartet hat. In den meisten Fällen ist dieses Verhalten ideal. Wenn der Vorgang jedoch im UI-Thread gestartet und dann durch einen Aufruf von Result blockiert wird, kann es zu einem Deadlock kommen.
Lösung
Um den Deadlock zu lösen, gibt es mehrere Methoden:
.ConfigureAwait(false)
zur Await-Anweisung wird sichergestellt, dass die Fortsetzung unabhängig vom aufrufenden Kontext immer im Thread-Pool geplant wird. Weitere Hinweise
Das obige ist der detaillierte Inhalt vonWarum bleibt meine asynchrone C#-Aktion hängen, wenn ich auf die Ergebniseigenschaft der Aufgabe zugreife?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!