Sdílet prostřednictvím


explicit (Referenční dokumentace jazyka C#)

explicit Klíčové slovo prohlašuje operátor převodu uživatelem definovaný typ musí být vyvolána s přetypování.Například tento operátor převede ze třídy s názvem třídy se nazývá Celsia Fahrenheita:

// Must be defined inside a class called Fahrenheit: 
public static explicit operator Celsius(Fahrenheit fahr)
{
    return new Celsius((5.0f / 9.0f) * (fahr.degrees - 32));
}

Tento operátor převodu lze vyvolat následovně:

Fahrenheit fahr = new Fahrenheit(100.0f);
Console.Write("{0} Fahrenheit", fahr.Degrees);
Celsius c = (Celsius)fahr;

Převede operátor převodu z typu zdroje typ cíle.Typ zdroje poskytuje operátor převodu.Na rozdíl od implicitní převod musí vyvolat operátory explicitní převod pomocí přetypování.Pokud operace převodu může způsobit výjimky nebo ztrátu informací, by ji označit explicit.To zabrání kompilátoru tiše vyvolání operace převodu se případně nepředvídatelné následky.

Vynechání přetypování výsledky v chybě kompilace CS0266.

Další informace naleznete v tématu Použití operátorů převodu (Průvodce programováním v C#).

Příklad

Následující příklad uvádí Fahrenheit a Celsius třídy, z nichž každý obsahuje explicitní operátor převodu do jiné třídy.

class Celsius
{
    public Celsius(float temp)
    {
        degrees = temp;
    }
    public static explicit operator Fahrenheit(Celsius c)
    {
        return new Fahrenheit((9.0f / 5.0f) * c.degrees + 32);
    }
    public float Degrees
    {
        get { return degrees; }
    }
    private float degrees;
}

class Fahrenheit
{
    public Fahrenheit(float temp)
    {
        degrees = temp;
    }
    // Must be defined inside a class called Fahrenheit: 
    public static explicit operator Celsius(Fahrenheit fahr)
    {
        return new Celsius((5.0f / 9.0f) * (fahr.degrees - 32));
    }
    public float Degrees
    {
        get { return degrees; }
    }
    private float degrees;
}

class MainClass
{
    static void Main()
    {
        Fahrenheit fahr = new Fahrenheit(100.0f);
        Console.Write("{0} Fahrenheit", fahr.Degrees);
        Celsius c = (Celsius)fahr;

        Console.Write(" = {0} Celsius", c.Degrees);
        Fahrenheit fahr2 = (Fahrenheit)c;
        Console.WriteLine(" = {0} Fahrenheit", fahr2.Degrees);
    }
}
// Output: 
// 100 Fahrenheit = 37.77778 Celsius = 100 Fahrenheit

Následující příklad definuje strukturu, Digit, která představuje jednociferné desítkové.Operátor je definován pro převody z byte na Digit, ale protože ne všechny bajty lze převést na Digit, je explicitní převod.

struct Digit
{
    byte value;
    public Digit(byte value)
    {
        if (value > 9)
        {
            throw new ArgumentException();
        }
        this.value = value;
    }

    // Define explicit byte-to-Digit conversion operator: 
    public static explicit operator Digit(byte b)
    {
        Digit d = new Digit(b);
        Console.WriteLine("conversion occurred");
        return d;
    }
}

class ExplicitTest
{
    static void Main()
    {
        try
        {
            byte b = 3;
            Digit d = (Digit)b; // explicit conversion
        }
        catch (Exception e)
        {
            Console.WriteLine("{0} Exception caught.", e);
        }
    }
}
/*
Output:
conversion occurred
*/

Specifikace jazyka C#

Další informace najdete v tématu Specifikace jazyka C#. Specifikace jazyka je úplným a rozhodujícím zdrojem pro syntaxi a použití jazyka C#.

Viz také

Úkoly

Postupy: Implementace uživatelem definovaných převodů mezi strukturami (Průvodce programováním v C#)

Referenční dokumentace

Klíčová slova jazyka C#

implicit (referenční dokumentace jazyka C#)

operator (Referenční dokumentace jazyka C#)

Koncepty

Průvodce programováním v C#

Další zdroje

Referenční dokumentace jazyka C#

Zřetězené explicitní převody uživatelem definované v jazyce C#