Maison > développement back-end > C++ > Pourquoi Async Void provoque-t-il « System.InvalidOperationException » dans ASP.NET ?

Pourquoi Async Void provoque-t-il « System.InvalidOperationException » dans ASP.NET ?

Susan Sarandon
Libérer: 2025-01-04 16:25:39
original
672 Les gens l'ont consulté

Why Does Async Void Cause `System.InvalidOperationException` in ASP.NET?

Comprendre le vide asynchrone dans ASP.Net : nombre d'opérations en suspens

Problème : Méthodes de vide asynchrone dans ASP.Net les candidatures soulèvent les éléments suivants exception :

System.InvalidOperationException: An asynchronous module or handler 
completed while an asynchronous operation was still pending
Copier après la connexion

Explication :

Les méthodes asynchrones dans ASP.Net incrémentent le nombre d'opérations en attente lors de l'appel et le décrémentent à la fin. Les méthodes async void notifient directement le ASP.Net SynchronizationContext, en contournant le framework MVC.

Retour de tâche vs. Async Void :

Contrairement aux méthodes async void, renvoyant une tâche de méthodes asynchrones :

  • Permet au framework de gérer la tâche renvoyée et d'attendre son achèvement
  • Assure une bonne synchronisation avec le cycle de vie de la demande
  • Évite l'exception causée par le retour anticipé des demandes (une pratique courante avec l'annulation asynchrone)

Dans l'exemple fourni :

  • ThisPageWillLoad() utilise une tâche asynchrone, qui fonctionne comme prévu car le framework MVC attend le retour tâche.
  • ThisPageWillNotLoad() utilise async void, provoquant l'exception car ASP.Net s'attend à ce que la méthode soit terminée avant la fin du chargement de la page, alors que la méthode async void n'est pas encore terminée.

Idée fausse « Fire and Forget » :

Les méthodes void asynchrones ne doivent pas être considérées comme « fire and Forget » oublier" dans ASP.Net. Bien qu'ils puissent sembler tirer et oublier dans certains scénarios, la sémantique de gestion des erreurs indique qu'ils ne sont pas vraiment oublieux.

Considérations supplémentaires :

  • Le retour de Task et l'utilisation simultanée de async void ne sont pas pris en charge.
  • Certaines bibliothèques tierces peuvent utiliser async void, mais c'est essentiel pour éviter d'utiliser de telles bibliothèques car elles peuvent entraîner des complications.
  • Si vous devez utiliser TAP sur EAP, envisagez TAP-over-APM ou encapsulez le composant EAP avec Task.Run.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal