Decimal.ToUInt16(Decimal) 方法

定義

重要

此 API 不符合 CLS 規範。

符合 CLS 規範替代方案
System.Decimal.ToInt32(Decimal)

將指定的 Decimal 值轉換為對等的 16 位元不帶正負號整數。

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

參數

value
Decimal

要轉換的十進位數字。

傳回

16 位元不帶正負號的整數,等於 value 的值。

屬性

例外狀況

範例

下列範例會使用 方法, ToUInt16 將十進位數轉換成 UInt16 值。

C#
using System;

class Example
{
   public static void Main( )
   {
      decimal[] values = { 123m, new Decimal(123000, 0, 0, false, 3),
                           123.999m, 65535.999m, 65536m,
                           32767.999m, 32768m, -0.999m,
                           -1m,  -32768.999m, -32769m };

      foreach (var value in values) {
         try {
            ushort number = Decimal.ToUInt16(value);
            Console.WriteLine("{0} --> {1}", value, number);
         }
         catch (OverflowException e)
         {
             Console.WriteLine("{0}: {1}", e.GetType().Name, value);
         }
      }
   }
}
// The example displays the following output:
//     123 --> 123
//     123.000 --> 123
//     123.999 --> 123
//     65535.999 --> 65535
//     OverflowException: 65536
//     32767.999 --> 32767
//     32768 --> 32768
//     -0.999 --> 0
//     OverflowException: -1
//     OverflowException: -32768.999
//     OverflowException: -32769

備註

傳回值是十進位值的整數部分;小數位數會截斷。

您也可以使用 Explicit 指派運算子,將值轉換成 Decimal 16 位不帶正負號的整數。 因為運算子會執行縮小轉換,所以您必須在 C# 中使用轉換運算子,或在 Visual Basic 中使用轉換函式。

適用於

產品 版本
.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

另請參閱