Exception.HResult Vlastnost

Definice

Získá nebo nastaví HRESULT, kódovaná číselná hodnota, která je přiřazena ke konkrétní výjimce.

C#
public int HResult { get; protected set; }
C#
public int HResult { get; set; }
C#
protected int HResult { get; set; }

Hodnota vlastnosti

Hodnota HRESULT.

Příklady

Následující příklad kódu definuje odvozenou Exception třídu, která nastaví HResult vlastnost na vlastní hodnotu v jeho konstruktoru.

C#
// Example for the Exception.HResult property.
using System;

namespace NDP_UE_CS
{
    // Create the derived exception class.
    class SecondLevelException : Exception
    {
        const int SecondLevelHResult = unchecked( (int)0x81234567 );

        // Set HResult for this exception, and include it in
        // the exception message.
        public SecondLevelException( string message, Exception inner ) :
            base( string.Format( "(HRESULT:0x{1:X8}) {0}",
                message, SecondLevelHResult ), inner )
        {
            HResult = SecondLevelHResult;
        }
    }

    class HResultDemo
    {
        public static void Main()
        {
            // This function forces a division by 0 and throws
            // a second exception.
            try
            {
                try
                {
                    int  zero = 0;
                    int  ecks = 1 / zero;
                }
                catch( Exception ex )
                {
                    throw new SecondLevelException(
                        "Forced a division by 0 and threw " +
                        "a second exception.", ex );
                }
            }
            catch( Exception ex )
            {
                Console.WriteLine( ex.ToString( ) );
            }
        }
    }
}

/*
This example of Exception.HResult generates the following output.

NDP_UE_CS.SecondLevelException: (HRESULT:0x81234567) Forced a division by 0 and
 threw a second exception. ---> System.DivideByZeroException: Attempted to divi
de by zero.
   at NDP_UE_CS.HResultDemo.Main()
   --- End of inner exception stack trace ---
   at NDP_UE_CS.HResultDemo.Main()
*/

Poznámky

HRESULT je 32bitová hodnota rozdělená do tří různých polí: kód závažnosti, kód zařízení a kód chyby. Kód závažnosti označuje, jestli vrácená hodnota představuje informace, upozornění nebo chybu. Kód zařízení identifikuje oblast systému zodpovědného za chybu. Kód chyby je jedinečné číslo, které je přiřazeno, aby představovalo výjimku. Každá výjimka se mapuje na odlišnou hodnotu HRESULT. Když spravovaný kód vyvolá výjimku, modul runtime předá HRESULT klientovi modelu COM. Když nespravovaný kód vrátí chybu, hodnota HRESULT se převede na výjimku, která je pak vyvolána modulem runtime. Informace o hodnotách HRESULT a jejich odpovídajících výjimkách rozhraní .NET Framework najdete v tématu Postupy: Mapování HRESULT a výjimek. Seznam hodnot, se kterými se s největší pravděpodobností setkáte, najdete v tématu Běžné hodnoty HRESULT v dokumentaci k Windows.

Počínaje rozhraním .NET Framework 4.5 HResult je setter vlastnosti chráněn, zatímco jeho getter je veřejný. V předchozích verzích rozhraní .NET Framework jsou chráněny getter i setter.

Platí pro

Produkt Verze
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Viz také