Note
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier les répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de changer de répertoire.
Les fonctionnalités de gestion des exceptions du langage C# vous aident à gérer les situations inattendues ou exceptionnelles qui se produisent lorsqu’un programme est en cours d’exécution. La gestion des exceptions utilise les mots clés try, catch et finally pour essayer des actions qui peuvent ne pas réussir, pour gérer les défaillances quand vous décidez qu’il est raisonnable de le faire, et pour nettoyer les ressources par la suite. Les exceptions peuvent être générées par le Common Language Runtime (CLR), par les bibliothèques .NET ou tierces, ou par code d’application. Les exceptions sont créées à l’aide du throw mot clé.
Dans de nombreux cas, une exception peut être levée non par une méthode que votre code a appelée directement, mais par une autre méthode plus bas dans la pile des appels. Lorsqu’une exception est levée, le CLR décompresse la pile, en recherchant une méthode avec un catch bloc pour le type d’exception spécifique, et exécute le premier catch bloc trouvé. S’il ne trouve aucun bloc approprié catch n’importe où dans la pile des appels, il met fin au processus et affiche un message à l’utilisateur.
Dans cet exemple, une méthode teste la division par zéro et intercepte l’erreur. Sans la gestion des exceptions, ce programme se terminerait avec une erreur DivideByZeroException n'a pas été gérée.
public class ExceptionTest
{
static double SafeDivision(double x, double y)
{
if (y == 0)
throw new DivideByZeroException();
return x / y;
}
public static void Main()
{
// Input for test purposes. Change the values to see
// exception handling behavior.
double a = 98, b = 0;
double result;
try
{
result = SafeDivision(a, b);
Console.WriteLine($"{a} divided by {b} = {result}");
}
catch (DivideByZeroException)
{
Console.WriteLine("Attempted divide by zero.");
}
}
}
Vue d’ensemble des exceptions
Les exceptions ont les propriétés suivantes :
- Les exceptions sont des types qui dérivent finalement de
System.Exception. - Utilisez un bloc
tryautour des instructions qui peuvent lever des exceptions. - Une fois qu’une exception se produit dans le
trybloc, le flux de contrôle passe au premier gestionnaire d’exceptions associé présent n’importe où dans la pile des appels. En C#, lecatchmot clé est utilisé pour définir un gestionnaire d’exceptions. - Si aucun gestionnaire d’exceptions pour une exception donnée n’est présent, le programme cesse d’exécuter avec un message d’erreur.
- N’interceptez pas une exception à moins que vous puissiez la gérer tout en laissant l’application dans un état connu. Si vous interceptez
System.Exception, levez-la de nouveau avec le mot cléthrowà la fin du bloccatch. - Si un bloc définit une
catchvariable d’exception, vous pouvez l’utiliser pour obtenir plus d’informations sur le type d’exception qui s’est produit. - Les exceptions peuvent être générées explicitement par un programme à l’aide du
throwmot clé. - Les objets d’exception contiennent des informations détaillées sur l’erreur, telles que l’état de la pile des appels et une description textuelle de l’erreur.
- Le code d’un
finallybloc est exécuté indépendamment de la levée d’une exception. Utilisez unfinallybloc pour libérer des ressources, par exemple pour fermer les flux ou fichiers ouverts dans letrybloc. - Les exceptions managées dans .NET sont implémentées au-dessus du mécanisme de gestion des exceptions structurées Win32. Pour plus d’informations, consultez Gestion des exceptions structurées (C/C++) et Cours accéléré sur les profondeurs de la gestion des exceptions structurées Win32.
Spécification du langage C#
Pour plus d’informations, consultez Exceptions dans la spécification du langage C#. La spécification du langage est la source de référence pour la syntaxe C# et son utilisation.