Problembehandlung bei Ausnahmen: System.ArgumentException
Aktualisiert: Juli 2008
Eine ArgumentException-Ausnahme wird ausgelöst, wenn mindestens eines der für eine Methode bereitgestellten Argumente nicht der Parameterspezifikation der Methode entspricht.
Im folgenden Beispiel wird eine Ausnahme ausgelöst, wenn das an die DivideByTwo-Methode gesendete Argument keine gerade Zahl ist.
Module Module1
Sub Main()
' ArgumentException is not thrown in DivideByTwo because 10 is
' an even number.
Console.WriteLine("10 divided by 2 is {0}", DivideByTwo(10))
Try
' ArgumentException is thrown in DivideByTwo because 7 is
' not an even number.
Console.WriteLine("7 divided by 2 is {0}", DivideByTwo(7))
Catch argEx As ArgumentException
' Tell the user which problem is encountered.
Console.WriteLine("7 cannot be evenly divided by 2.")
Console.WriteLine("Exception message: " & argEx.Message)
End Try
' Uncomment the next statement to see what happens if you call
' DivideByTwo directly.
'Console.WriteLine(DivideByTwo(7))
End Sub
Function DivideByTwo(ByVal num As Integer) As Integer
' If num is an odd number, throw an ArgumentException. The
' ArgumentException class provides a number of constructors
' that you can choose from.
If num Mod 2 = 1 Then
Throw New ArgumentException("Argument for num must be" & _
" an even number.")
End If
' Value of num is even, so return half of its value.
Return num / 2
End Function
End Module
Alle Instanzen der ArgumentException-Klasse sollten Informationen enthalten, die ungültige Argumente und den zulässigen Wertebereich angeben. Wenn eine präzisere Ausnahme, wie zum Beispiel ArgumentNullException oder ArgumentOutOfRangeException, die Situation genau beschreibt, sollte sie anstelle von ArgumentException verwendet werden.
Weitere Informationen über diese Ausnahme sowie Beispiele in anderen Sprachen finden Sie unter ArgumentException. Eine Liste mit weiteren Konstruktoren finden Sie unter ArgumentException().
Siehe auch
Aufgaben
Gewusst wie: Weitere Informationen über eine Ausnahme mit dem Ausnahmen-Assistenten
Referenz
Änderungsprotokoll
Date |
Versionsgeschichte |
Grund |
---|---|---|
Juli 2008 |
Beispiel und weitere Informationen über die Ausnahme hinzugefügt. |
Kundenfeedback. |