Lire en anglais

Partager via


Decimal.Explicit Opérateur

Définition

Définit une conversion explicite entre un objet Decimal et un autre type.

Surcharges

Explicit(Single to Decimal)

Définit une conversion explicite d'un nombre à virgule flottante simple précision en Decimal.

Explicit(Double to Decimal)

Définit une conversion explicite d'un nombre à virgule flottante double précision en Decimal.

Explicit(Decimal to UInt64)

Définit une conversion explicite de Decimal en entier non signé 64 bits.

Cette API n'est pas conforme CLS.

Explicit(Decimal to UInt32)

Définit une conversion explicite de Decimal en entier non signé 32 bits.

Cette API n'est pas conforme CLS.

Explicit(Decimal to UInt16)

Définit une conversion explicite de Decimal en entier non signé 16 bits.

Cette API n'est pas conforme CLS.

Explicit(Decimal to SByte)

Définit une conversion explicite de Decimal en entier signé 8 bits.

Cette API n'est pas conforme CLS.

Explicit(Decimal to Single)

Définit une conversion explicite de Decimal en nombre à virgule flottante simple précision.

Explicit(Decimal to Int32)

Définit une conversion explicite de Decimal en entier signé 32 bits.

Explicit(Decimal to Int16)

Définit une conversion explicite de Decimal en entier signé 16 bits.

Explicit(Decimal to Double)

Définit une conversion explicite de Decimal en nombre à virgule flottante double précision.

Explicit(Decimal to Char)

Définit une conversion explicite de Decimal en caractère Unicode.

Explicit(Decimal to Byte)

Définit une conversion explicite de Decimal en entier non signé 8 bits.

Explicit(Decimal to Int64)

Définit une conversion explicite de Decimal en entier signé 64 bits.

Explicit(Single to Decimal)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite d'un nombre à virgule flottante simple précision en Decimal.

C#
public static explicit operator decimal (float value);

Paramètres

value
Single

Nombre à virgule flottante simple précision à convertir.

Retours

Nombre à virgule flottante simple précision converti.

Exceptions

value est supérieur à Decimal.MaxValue ou inférieur à Decimal.MinValue.

- ou -

value a la valeur NaN, PositiveInfinity ou NegativeInfinity.

Exemples

L’exemple suivant convertit des valeurs en nombres Single à Decimal l’aide de l’opérateur Single de conversion to Decimal . Cette conversion nécessite l’opérateur op_Explicit en Visual Basic.

C#
// Example of the explicit conversion from float to decimal.
using System;

class DecimalFromSingleDemo
{
    const string formatter = "{0,16:E7}{1,33}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the float argument; catch exceptions that are thrown.
    public static void DecimalFromSingle( float argument )
    {
        object decValue;

        // Convert the float argument to a decimal value.
        try
        {
            decValue = (decimal)argument;
        }
        catch( Exception ex )
        {
            decValue = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument, decValue );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversion from float " +
            "to decimal \ngenerates the following output.\n" );
        Console.WriteLine( formatter, "float argument",
            "decimal value" );
        Console.WriteLine( formatter, "--------------",
            "-------------" );

        // Convert float values and display the results.
        DecimalFromSingle( 1.2345E-30F );
        DecimalFromSingle( 1.2345E-26F );
        DecimalFromSingle( 1.23456E-22F );
        DecimalFromSingle( 1.23456E-12F );
        DecimalFromSingle( 1.234567F );
        DecimalFromSingle( 1.234567E+12F );
        DecimalFromSingle( 1.2345678E+28F );
        DecimalFromSingle( 1.2345678E+30F );
    }
}

/*
This example of the explicit conversion from float to decimal
generates the following output.

  float argument                    decimal value
  --------------                    -------------
  1.2345000E-030                                0
  1.2345000E-026   0.0000000000000000000000000123
  1.2345600E-022    0.000000000000000000000123456
  1.2345600E-012              0.00000000000123456
  1.2345671E+000                         1.234567
  1.2345670E+012                    1234567000000
  1.2345678E+028    12345680000000000000000000000
  1.2345678E+030                OverflowException
*/

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Double to Decimal)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite d'un nombre à virgule flottante double précision en Decimal.

C#
public static explicit operator decimal (double value);

Paramètres

value
Double

Nombre à virgule flottante double précision à convertir.

Retours

Nombre à virgule flottante double précision converti.

Exceptions

value est supérieur à Decimal.MaxValue ou inférieur à Decimal.MinValue.

- ou -

value a la valeur NaN, PositiveInfinity ou NegativeInfinity.

Exemples

L’exemple suivant convertit des valeurs en nombres Double à Decimal l’aide de l’opérateur Double de conversion to Decimal . Cette conversion nécessite l’opérateur op_Explicit en Visual Basic.

C#
// Example of the explicit conversion from double to decimal.
using System;

class DecimalFromDoubleDemo
{
    const string formatter = "{0,25:E16}{1,33}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the double argument; catch exceptions that are thrown.
    public static void DecimalFromDouble( double argument )
    {
        object decValue;

        // Convert the double argument to a decimal value.
        try
        {
            decValue = (decimal)argument;
        }
        catch( Exception ex )
        {
            decValue = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument, decValue );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversion from double " +
            "to decimal \ngenerates the following output.\n" );
        Console.WriteLine( formatter, "double argument",
            "decimal value" );
        Console.WriteLine( formatter, "---------------",
            "-------------" );

        // Convert double values and display the results.
        DecimalFromDouble( 1.234567890123E-30 );
        DecimalFromDouble( 1.2345678901234E-25 );
        DecimalFromDouble( 1.23456789012345E-20 );
        DecimalFromDouble( 1.234567890123456E-10 );
        DecimalFromDouble( 1.2345678901234567 );
        DecimalFromDouble( 1.23456789012345678E+12 );
        DecimalFromDouble( 1.234567890123456789E+28 );
        DecimalFromDouble( 1.234567890123456789E+30 );
    }
}

/*
This example of the explicit conversion from double to decimal
generates the following output.

          double argument                    decimal value
          ---------------                    -------------
  1.2345678901230000E-030                                0
  1.2345678901233999E-025   0.0000000000000000000000001235
  1.2345678901234499E-020   0.0000000000000000000123456789
  1.2345678901234560E-010       0.000000000123456789012346
  1.2345678901234567E+000                 1.23456789012346
  1.2345678901234568E+012                 1234567890123.46
  1.2345678901234568E+028    12345678901234600000000000000
  1.2345678901234569E+030                OverflowException
*/

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to UInt64)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Important

Cette API n’est pas conforme CLS.

Définit une conversion explicite de Decimal en entier non signé 64 bits.

Cette API n'est pas conforme CLS.

C#
[System.CLSCompliant(false)]
public static explicit operator ulong (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 64 bits non signé représentant l'objet Decimal converti.

Attributs

Exceptions

value est négatif ou supérieur à UInt64.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à UInt64 l’aide de l’opérateur de conversion explicite Decimal en UInt64 .

C#
// Example of the explicit conversions from decimal to long and
// decimal to ulong.
using System;

class DecimalToU_Int64Demo
{
    const string formatter = "{0,25}{1,22}{2,22}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the decimal argument; catch exceptions that are thrown.
    public static void DecimalToU_Int64( decimal argument )
    {
        object Int64Value;
        object UInt64Value;

        // Convert the argument to a long value.
        try
        {
            Int64Value = (long)argument;
        }
        catch( Exception ex )
        {
            Int64Value = GetExceptionType( ex );
        }

        // Convert the argument to a ulong value.
        try
        {
            UInt64Value = (ulong)argument;
        }
        catch( Exception ex )
        {
            UInt64Value = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument,
            Int64Value, UInt64Value );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversions from decimal " +
            "to long \nand decimal to ulong generates the following " +
            "output. It displays \nseveral converted decimal " +
            "values.\n" );
        Console.WriteLine( formatter, "decimal argument",
            "long/exception", "ulong/exception" );
        Console.WriteLine( formatter, "----------------",
            "--------------", "---------------" );

        // Convert decimal values and display the results.
        DecimalToU_Int64( 123M );
        DecimalToU_Int64( new decimal( 123000, 0, 0, false, 3 ) );
        DecimalToU_Int64( 123.999M );
        DecimalToU_Int64( 18446744073709551615.999M );
        DecimalToU_Int64( 18446744073709551616M );
        DecimalToU_Int64( 9223372036854775807.999M );
        DecimalToU_Int64( 9223372036854775808M );
        DecimalToU_Int64( - 0.999M );
        DecimalToU_Int64( - 1M );
        DecimalToU_Int64( - 9223372036854775808.999M );
        DecimalToU_Int64( - 9223372036854775809M );
    }
}

/*
This example of the explicit conversions from decimal to long
and decimal to ulong generates the following output. It displays
several converted decimal values.

         decimal argument        long/exception       ulong/exception
         ----------------        --------------       ---------------
                      123                   123                   123
                  123.000                   123                   123
                  123.999                   123                   123
 18446744073709551615.999     OverflowException  18446744073709551615
     18446744073709551616     OverflowException     OverflowException
  9223372036854775807.999   9223372036854775807   9223372036854775807
      9223372036854775808     OverflowException   9223372036854775808
                   -0.999                     0                     0
                       -1                    -1     OverflowException
 -9223372036854775808.999  -9223372036854775808     OverflowException
     -9223372036854775809     OverflowException     OverflowException
*/

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .UInt64 La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur UInt64 à l’aide de C# et de Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToUInt64(Decimal) méthode ou Convert.ToUInt64(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to UInt32)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Important

Cette API n’est pas conforme CLS.

Alternative à la conformité CLS
System.Decimal.ToInt64(Decimal)

Définit une conversion explicite de Decimal en entier non signé 32 bits.

Cette API n'est pas conforme CLS.

C#
[System.CLSCompliant(false)]
public static explicit operator uint (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 32 bits non signé représentant l'objet Decimal converti.

Attributs

Exceptions

value est inférieur à UInt32.MinValue ou supérieur à UInt32.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à UInt32 l’aide de l’opérateur de conversion explicite Decimal en UInt32 .

C#
// Example of the explicit conversions from decimal to int and
// decimal to uint.
using System;

class DecimalToU_Int32Demo
{
    const string formatter = "{0,17}{1,19}{2,19}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the decimal argument; catch exceptions that are thrown.
    public static void DecimalToU_Int32( decimal argument )
    {
        object Int32Value;
        object UInt32Value;

        // Convert the argument to an int value.
        try
        {
            Int32Value = (int)argument;
        }
        catch( Exception ex )
        {
            Int32Value = GetExceptionType( ex );
        }

        // Convert the argument to a uint value.
        try
        {
            UInt32Value = (uint)argument;
        }
        catch( Exception ex )
        {
            UInt32Value = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument,
            Int32Value, UInt32Value );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversions from decimal " +
            "to int \nand decimal to uint generates the following " +
            "output. It displays \nseveral converted decimal " +
            "values.\n" );
        Console.WriteLine( formatter, "decimal argument",
            "int/exception", "uint/exception" );
        Console.WriteLine( formatter, "----------------",
            "-------------", "--------------" );

        // Convert decimal values and display the results.
        DecimalToU_Int32( 123M );
        DecimalToU_Int32( new decimal( 123000, 0, 0, false, 3 ) );
        DecimalToU_Int32( 123.999M );
        DecimalToU_Int32( 4294967295.999M );
        DecimalToU_Int32( 4294967296M );
        DecimalToU_Int32( 2147483647.999M );
        DecimalToU_Int32( 2147483648M );
        DecimalToU_Int32( - 0.999M );
        DecimalToU_Int32( - 1M );
        DecimalToU_Int32( - 2147483648.999M );
        DecimalToU_Int32( - 2147483649M );
    }
}

/*
This example of the explicit conversions from decimal to int
and decimal to uint generates the following output. It displays
several converted decimal values.

 decimal argument      int/exception     uint/exception
 ----------------      -------------     --------------
              123                123                123
          123.000                123                123
          123.999                123                123
   4294967295.999  OverflowException         4294967295
       4294967296  OverflowException  OverflowException
   2147483647.999         2147483647         2147483647
       2147483648  OverflowException         2147483648
           -0.999                  0                  0
               -1                 -1  OverflowException
  -2147483648.999        -2147483648  OverflowException
      -2147483649  OverflowException  OverflowException
*/

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .UInt32 La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur UInt32 à l’aide de C# et de Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToUInt32(Decimal) méthode ou Convert.ToUInt32(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to UInt16)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Important

Cette API n’est pas conforme CLS.

Définit une conversion explicite de Decimal en entier non signé 16 bits.

Cette API n'est pas conforme CLS.

C#
[System.CLSCompliant(false)]
public static explicit operator ushort (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 16 bits non signé représentant l'objet Decimal converti.

Attributs

Exceptions

value est inférieur à UInt16.MinValue ou supérieur à UInt16.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à UInt16 l’aide de l’opérateur de conversion explicite Decimal en UInt16 .

C#
// Example of the explicit conversions from decimal to short and
// decimal to ushort.
using System;

class DecimalToU_Int16Demo
{
    const string formatter = "{0,16}{1,19}{2,19}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the decimal argument; catch exceptions that are thrown.
    public static void DecimalToU_Int16( decimal argument )
    {
        object Int16Value;
        object UInt16Value;

        // Convert the argument to a short value.
        try
        {
            Int16Value = (short)argument;
        }
        catch( Exception ex )
        {
            Int16Value = GetExceptionType( ex );
        }

        // Convert the argument to a ushort value.
        try
        {
            UInt16Value = (ushort)argument;
        }
        catch( Exception ex )
        {
            UInt16Value = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument,
            Int16Value, UInt16Value );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversions from decimal " +
            "to short \nand decimal to ushort generates the " +
            "following output. It displays \nseveral converted " +
            "decimal values.\n" );
        Console.WriteLine( formatter, "decimal argument",
            "short/exception", "ushort/exception" );
        Console.WriteLine( formatter, "----------------",
            "---------------", "----------------" );

        // Convert decimal values and display the results.
        DecimalToU_Int16( 123M );
        DecimalToU_Int16( new decimal( 123000, 0, 0, false, 3 ) );
        DecimalToU_Int16( 123.999M );
        DecimalToU_Int16( 65535.999M );
        DecimalToU_Int16( 65536M );
        DecimalToU_Int16( 32767.999M );
        DecimalToU_Int16( 32768M );
        DecimalToU_Int16( - 0.999M );
        DecimalToU_Int16( - 1M );
        DecimalToU_Int16( - 32768.999M );
        DecimalToU_Int16( - 32769M );
    }
}

/*
This example of the explicit conversions from decimal to short
and decimal to ushort generates the following output. It displays
several converted decimal values.

decimal argument    short/exception   ushort/exception
----------------    ---------------   ----------------
             123                123                123
         123.000                123                123
         123.999                123                123
       65535.999  OverflowException              65535
           65536  OverflowException  OverflowException
       32767.999              32767              32767
           32768  OverflowException              32768
          -0.999                  0                  0
              -1                 -1  OverflowException
      -32768.999             -32768  OverflowException
          -32769  OverflowException  OverflowException
*/

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .UInt16 La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur UInt16 à l’aide de C# et de Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToUInt16(Decimal) méthode ou Convert.ToUInt16(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to SByte)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Important

Cette API n’est pas conforme CLS.

Alternative à la conformité CLS
System.Decimal.ToInt16(Decimal)

Définit une conversion explicite de Decimal en entier signé 8 bits.

Cette API n'est pas conforme CLS.

C#
[System.CLSCompliant(false)]
public static explicit operator sbyte (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 8 bits signé représentant le Decimal converti.

Attributs

Exceptions

value est inférieur à SByte.MinValue ou supérieur à SByte.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à SByte l’aide de l’opérateur de conversion explicite Decimal en SByte .

C#
using System;

class Example
{
    public static void Main()
    {
        // Define an array of decimal values.
       decimal[] values = { 78m, new Decimal(78000, 0, 0, false, 3),
                            78.999m, 255.999m, 256m, 127.999m,
                            128m, -0.999m, -1m, -128.999m, -129m };
       foreach (var value in values) {
          try {
              SByte byteValue = (SByte) value;
              Console.WriteLine("{0} ({1}) --> {2} ({3})", value,
                                value.GetType().Name, byteValue,
                                byteValue.GetType().Name);
           }
           catch (OverflowException) {
              Console.WriteLine("OverflowException: Cannot convert {0}",
                                value);
           }
       }
    }
}
// The example displays the following output:
//       78 (Decimal) --> 78 (SByte)
//       78.000 (Decimal) --> 78 (SByte)
//       78.999 (Decimal) --> 78 (SByte)
//       OverflowException: Cannot convert 255.999
//       OverflowException: Cannot convert 256
//       127.999 (Decimal) --> 127 (SByte)
//       OverflowException: Cannot convert 128
//       -0.999 (Decimal) --> 0 (SByte)
//       -1 (Decimal) --> -1 (SByte)
//       -128.999 (Decimal) --> -128 (SByte)
//       OverflowException: Cannot convert -129

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .SByte La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en et Byte une SByte valeur à l’aide de C# et Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToSByte(Decimal) méthode ou la Convert.ToSByte(Decimal) méthode .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to Single)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite de Decimal en nombre à virgule flottante simple précision.

C#
public static explicit operator float (decimal value);

Paramètres

value
Decimal

Valeur à convertir.

Retours

Nombre à virgule flottante simple précision représentant le Decimal converti.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à Single l’aide de l’opérateur de conversion explicite Decimal en Single .

C#
using System;

class Example
{
    public static void Main( )
    {
        // Define an array of decimal values.
        decimal[] values = { 0.0000000000000000000000000001M,
                             0.0000000000123456789123456789M,
                             123M, new decimal(123000000, 0, 0, false, 6),
                             123456789.123456789M,
                             123456789123456789123456789M,
                             decimal.MinValue, decimal.MaxValue };
        // Convert each value to a double.
        foreach (var value in values) {
            float dblValue = (float) value;
            Console.WriteLine("{0} ({1}) --> {2} ({3})", value,
                              value.GetType().Name, dblValue,
                              dblValue.GetType().Name);
       }
    }
}
// The example displays the following output:
//    0.0000000000000000000000000001 (Decimal) --> 1E-28 (Single)
//    0.0000000000123456789123456789 (Decimal) --> 1.234568E-11 (Single)
//    123 (Decimal) --> 123 (Single)
//    123.000000 (Decimal) --> 123 (Single)
//    123456789.123456789 (Decimal) --> 1.234568E+08 (Single)
//    123456789123456789123456789 (Decimal) --> 1.234568E+26 (Single)
//    -79228162514264337593543950335 (Decimal) --> -7.922816E+28 (Single)
//    79228162514264337593543950335 (Decimal) --> 7.922816E+28 (Single)

Remarques

Cette opération peut entraîner une perte de précision, car un nombre à virgule flottante simple précision a moins de chiffres significatifs qu’un Decimal.

Cet opérateur prend en charge la conversion explicite d’un Decimal en .Single La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur Single à l’aide de C# et de Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToSingle(Decimal) méthode ou Convert.ToSingle(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to Int32)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite de Decimal en entier signé 32 bits.

C#
public static explicit operator int (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 32 bits signé représentant l'objet Decimal converti.

Exceptions

value est inférieur à Int32.MinValue ou supérieur à Int32.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à Int32 l’aide de l’opérateur explicit Decimal to Int32 conversion.

C#
// Example of the explicit conversions from decimal to int and
// decimal to uint.
using System;

class DecimalToU_Int32Demo
{
    const string formatter = "{0,17}{1,19}{2,19}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the decimal argument; catch exceptions that are thrown.
    public static void DecimalToU_Int32( decimal argument )
    {
        object Int32Value;
        object UInt32Value;

        // Convert the argument to an int value.
        try
        {
            Int32Value = (int)argument;
        }
        catch( Exception ex )
        {
            Int32Value = GetExceptionType( ex );
        }

        // Convert the argument to a uint value.
        try
        {
            UInt32Value = (uint)argument;
        }
        catch( Exception ex )
        {
            UInt32Value = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument,
            Int32Value, UInt32Value );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversions from decimal " +
            "to int \nand decimal to uint generates the following " +
            "output. It displays \nseveral converted decimal " +
            "values.\n" );
        Console.WriteLine( formatter, "decimal argument",
            "int/exception", "uint/exception" );
        Console.WriteLine( formatter, "----------------",
            "-------------", "--------------" );

        // Convert decimal values and display the results.
        DecimalToU_Int32( 123M );
        DecimalToU_Int32( new decimal( 123000, 0, 0, false, 3 ) );
        DecimalToU_Int32( 123.999M );
        DecimalToU_Int32( 4294967295.999M );
        DecimalToU_Int32( 4294967296M );
        DecimalToU_Int32( 2147483647.999M );
        DecimalToU_Int32( 2147483648M );
        DecimalToU_Int32( - 0.999M );
        DecimalToU_Int32( - 1M );
        DecimalToU_Int32( - 2147483648.999M );
        DecimalToU_Int32( - 2147483649M );
    }
}

/*
This example of the explicit conversions from decimal to int
and decimal to uint generates the following output. It displays
several converted decimal values.

 decimal argument      int/exception     uint/exception
 ----------------      -------------     --------------
              123                123                123
          123.000                123                123
          123.999                123                123
   4294967295.999  OverflowException         4294967295
       4294967296  OverflowException  OverflowException
   2147483647.999         2147483647         2147483647
       2147483648  OverflowException         2147483648
           -0.999                  0                  0
               -1                 -1  OverflowException
  -2147483648.999        -2147483648  OverflowException
      -2147483649  OverflowException  OverflowException
*/

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .Int32 La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur Int32 à l’aide de C#, C++ et Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToInt32(Decimal) méthode ou Convert.ToInt32(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to Int16)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite de Decimal en entier signé 16 bits.

C#
public static explicit operator short (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 16 bits signé représentant l'objet Decimal converti.

Exceptions

value est inférieur à Int16.MinValue ou supérieur à Int16.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à Int16 l’aide de l’opérateur explicit Decimal to Int16 conversion.

C#
// Example of the explicit conversions from decimal to short and
// decimal to ushort.
using System;

class DecimalToU_Int16Demo
{
    const string formatter = "{0,16}{1,19}{2,19}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the decimal argument; catch exceptions that are thrown.
    public static void DecimalToU_Int16( decimal argument )
    {
        object Int16Value;
        object UInt16Value;

        // Convert the argument to a short value.
        try
        {
            Int16Value = (short)argument;
        }
        catch( Exception ex )
        {
            Int16Value = GetExceptionType( ex );
        }

        // Convert the argument to a ushort value.
        try
        {
            UInt16Value = (ushort)argument;
        }
        catch( Exception ex )
        {
            UInt16Value = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument,
            Int16Value, UInt16Value );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversions from decimal " +
            "to short \nand decimal to ushort generates the " +
            "following output. It displays \nseveral converted " +
            "decimal values.\n" );
        Console.WriteLine( formatter, "decimal argument",
            "short/exception", "ushort/exception" );
        Console.WriteLine( formatter, "----------------",
            "---------------", "----------------" );

        // Convert decimal values and display the results.
        DecimalToU_Int16( 123M );
        DecimalToU_Int16( new decimal( 123000, 0, 0, false, 3 ) );
        DecimalToU_Int16( 123.999M );
        DecimalToU_Int16( 65535.999M );
        DecimalToU_Int16( 65536M );
        DecimalToU_Int16( 32767.999M );
        DecimalToU_Int16( 32768M );
        DecimalToU_Int16( - 0.999M );
        DecimalToU_Int16( - 1M );
        DecimalToU_Int16( - 32768.999M );
        DecimalToU_Int16( - 32769M );
    }
}

/*
This example of the explicit conversions from decimal to short
and decimal to ushort generates the following output. It displays
several converted decimal values.

decimal argument    short/exception   ushort/exception
----------------    ---------------   ----------------
             123                123                123
         123.000                123                123
         123.999                123                123
       65535.999  OverflowException              65535
           65536  OverflowException  OverflowException
       32767.999              32767              32767
           32768  OverflowException              32768
          -0.999                  0                  0
              -1                 -1  OverflowException
      -32768.999             -32768  OverflowException
          -32769  OverflowException  OverflowException
*/

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .Int16 La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur à Int16 l’aide de C#, Visual Basic et C++. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToInt16(Decimal) méthode ou Convert.ToInt16(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to Double)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite de Decimal en nombre à virgule flottante double précision.

C#
public static explicit operator double (decimal value);

Paramètres

value
Decimal

Valeur à convertir.

Retours

Nombre à virgule flottante double précision représentant le Decimal converti.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à Double l’aide de l’opérateur explicit Decimal to Double conversion.

C#
using System;

class Example
{
    public static void Main( )
    {
        // Define an array of decimal values.
        decimal[] values = { 0.0000000000000000000000000001M,
                             0.0000000000123456789123456789M,
                             123M, new decimal(123000000, 0, 0, false, 6),
                             123456789.123456789M,
                             123456789123456789123456789M,
                             decimal.MinValue, decimal.MaxValue };
        // Convert each value to a double.
        foreach (var value in values) {
            double dblValue = (double) value;
            Console.WriteLine("{0} ({1}) --> {2} ({3})", value,
                              value.GetType().Name, dblValue,
                              dblValue.GetType().Name);
       }
    }
}
// The example displays the following output:
//    0.0000000000000000000000000001 (Decimal) --> 1E-28 (Double)
//    0.0000000000123456789123456789 (Decimal) --> 1.23456789123457E-11 (Double)
//    123 (Decimal) --> 123 (Double)
//    123.000000 (Decimal) --> 123 (Double)
//    123456789.123456789 (Decimal) --> 123456789.123457 (Double)
//    123456789123456789123456789 (Decimal) --> 1.23456789123457E+26 (Double)
//    -79228162514264337593543950335 (Decimal) --> -7.92281625142643E+28 (Double)
//    79228162514264337593543950335 (Decimal) --> 7.92281625142643E+28 (Double)

Remarques

Cette opération peut entraîner une perte de précision, car un nombre à virgule flottante double précision a moins de chiffres significatifs qu’un Decimal.

Cet opérateur prend en charge la conversion explicite d’un Decimal en .Double La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur Double à l’aide de C#, C++ et Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToDouble(Decimal) méthode ou Convert.ToDouble(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to Char)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite de Decimal en caractère Unicode.

C#
public static explicit operator char (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Caractère Unicode qui représente le Decimal converti.

Exceptions

value est inférieur à Char.MinValue ou supérieur à Char.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs (caractères Unicode) à Char l’aide de l’opérateur explicit Decimal to Char conversion.

C#
using System;

class Example
{
   public static void Main( )
   {
      // Define an array of decimal values.
      decimal[] values = { 3.33m, 55.5m, 77.7m, 123m, 123.999m, 170m,
                           188.88m, 222m, 244m, 8217m, 8250m, 65536m,
                           -1m };
      // Convert each value to a Char.
      foreach (decimal value in values) {
         try {
            char charValue = (char) value;
            Console.WriteLine("{0} --> {1} ({2:X4})", value,
                              charValue, (ushort) charValue);
         }
         catch (OverflowException) {
            Console.WriteLine("OverflowException: Cannot convert {0}",
                              value);
         }
      }
   }
}
// The example displays the following output:
//       3.33 --> ? (0003)
//       55.5 --> 7 (0037)
//       77.7 --> M (004D)
//       123 --> { (007B)
//       123.999 --> { (007B)
//       170 --> ª (00AA)
//       188.88 --> ¼ (00BC)
//       222 --> _ (00DE)
//       244 --> ô (00F4)
//       8217 --> ' (2019)
//       8250 --> > (203A)
//       OverflowException: Cannot convert 65536
//       OverflowException: Cannot convert -1

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .Char La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents, ou ne pas prendre en charge la conversion du tout. Par exemple, les compilateurs Visual Basic et C++ ne prennent pas en charge une conversion explicite DecimalChar .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to Byte)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite de Decimal en entier non signé 8 bits.

C#
public static explicit operator byte (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 8 bits non signé représentant le Decimal converti.

Exceptions

value est inférieur à Byte.MinValue ou supérieur à Byte.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à Byte l’aide de l’opérateur explicit Decimal to Byte conversion.

C#
using System;

class Example
{
    public static void Main()
    {
        // Define an array of decimal values.
       decimal[] values = { 78m, new Decimal(78000, 0, 0, false, 3),
                            78.999m, 255.999m, 256m, 127.999m,
                            128m, -0.999m, -1m, -128.999m, -129m };
       foreach (var value in values) {
          try {
              Byte byteValue = (Byte) value;
              Console.WriteLine("{0} ({1}) --> {2} ({3})", value,
                                value.GetType().Name, byteValue,
                                byteValue.GetType().Name);
           }
           catch (OverflowException) {
              Console.WriteLine("OverflowException: Cannot convert {0}",
                                value);
           }
       }
    }
}
// The example displays the following output:
//       78 (Decimal) --> 78 (Byte)
//       78.000 (Decimal) --> 78 (Byte)
//       78.999 (Decimal) --> 78 (Byte)
//       255.999 (Decimal) --> 255 (Byte)
//       OverflowException: Cannot convert 256
//       127.999 (Decimal) --> 127 (Byte)
//       128 (Decimal) --> 128 (Byte)
//       -0.999 (Decimal) --> 0 (Byte)
//       OverflowException: Cannot convert -1
//       OverflowException: Cannot convert -128.999
//       OverflowException: Cannot convert -129

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .Byte La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur Byte à l’aide de C#, C++ et Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToByte(Decimal) méthode ou Convert.ToByte(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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

Explicit(Decimal to Int64)

Source:
Decimal.cs
Source:
Decimal.cs
Source:
Decimal.cs

Définit une conversion explicite de Decimal en entier signé 64 bits.

C#
public static explicit operator long (decimal value);

Paramètres

value
Decimal

La valeur à convertir.

Retours

Entier 64 bits signé représentant l'objet Decimal converti.

Exceptions

value est inférieur à Int64.MinValue ou supérieur à Int64.MaxValue.

Exemples

L’exemple suivant convertit des nombres Decimal en valeurs à Int64 l’aide de l’opérateur explicit Decimal to Int64 conversion.

C#
// Example of the explicit conversions from decimal to long and
// decimal to ulong.
using System;

class DecimalToU_Int64Demo
{
    const string formatter = "{0,25}{1,22}{2,22}";

    // Get the exception type name; remove the namespace prefix.
    public static string GetExceptionType( Exception ex )
    {
        string exceptionType = ex.GetType( ).ToString( );
        return exceptionType.Substring(
            exceptionType.LastIndexOf( '.' ) + 1 );
    }

    // Convert the decimal argument; catch exceptions that are thrown.
    public static void DecimalToU_Int64( decimal argument )
    {
        object Int64Value;
        object UInt64Value;

        // Convert the argument to a long value.
        try
        {
            Int64Value = (long)argument;
        }
        catch( Exception ex )
        {
            Int64Value = GetExceptionType( ex );
        }

        // Convert the argument to a ulong value.
        try
        {
            UInt64Value = (ulong)argument;
        }
        catch( Exception ex )
        {
            UInt64Value = GetExceptionType( ex );
        }

        Console.WriteLine( formatter, argument,
            Int64Value, UInt64Value );
    }

    public static void Main( )
    {
        Console.WriteLine(
            "This example of the explicit conversions from decimal " +
            "to long \nand decimal to ulong generates the following " +
            "output. It displays \nseveral converted decimal " +
            "values.\n" );
        Console.WriteLine( formatter, "decimal argument",
            "long/exception", "ulong/exception" );
        Console.WriteLine( formatter, "----------------",
            "--------------", "---------------" );

        // Convert decimal values and display the results.
        DecimalToU_Int64( 123M );
        DecimalToU_Int64( new decimal( 123000, 0, 0, false, 3 ) );
        DecimalToU_Int64( 123.999M );
        DecimalToU_Int64( 18446744073709551615.999M );
        DecimalToU_Int64( 18446744073709551616M );
        DecimalToU_Int64( 9223372036854775807.999M );
        DecimalToU_Int64( 9223372036854775808M );
        DecimalToU_Int64( - 0.999M );
        DecimalToU_Int64( - 1M );
        DecimalToU_Int64( - 9223372036854775808.999M );
        DecimalToU_Int64( - 9223372036854775809M );
    }
}

/*
This example of the explicit conversions from decimal to long
and decimal to ulong generates the following output. It displays
several converted decimal values.

         decimal argument        long/exception       ulong/exception
         ----------------        --------------       ---------------
                      123                   123                   123
                  123.000                   123                   123
                  123.999                   123                   123
 18446744073709551615.999     OverflowException  18446744073709551615
     18446744073709551616     OverflowException     OverflowException
  9223372036854775807.999   9223372036854775807   9223372036854775807
      9223372036854775808     OverflowException   9223372036854775808
                   -0.999                     0                     0
                       -1                    -1     OverflowException
 -9223372036854775808.999  -9223372036854775808     OverflowException
     -9223372036854775809     OverflowException     OverflowException
*/

Remarques

Cet opérateur prend en charge la conversion explicite d’un Decimal en .Int64 La syntaxe de ces conversions explicites dépend du langage, et les compilateurs de langage individuels peuvent fournir des implémentations différentes et retourner des résultats différents. L’exemple illustre les différentes valeurs de retour lorsque vous convertissez explicitement une Decimal valeur en valeur à Int64 l’aide de C# et de Visual Basic. Pour effectuer une conversion indépendante de la langue, vous pouvez appeler la Decimal.ToInt64(Decimal) méthode ou Convert.ToInt64(Decimal) .

Voir aussi

S’applique à

.NET 9 et autres versions
Produit Versions
.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
.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