共用方式為


Math.Floor 方法

定義

傳回小於或等於指定數位的最大整數值。

多載

Floor(Decimal)

傳回小於或等於指定十進位數的最大整數值。

Floor(Double)

傳回小於或等於指定雙精確度浮點數的最大整數值。

備註

此方法的行為遵循 IEEE Standard 754 第 4 節。 這種四捨五入有時稱為向負無限四捨五入。

Floor(Decimal)

來源:
Math.cs
來源:
Math.cs
來源:
Math.cs

傳回小於或等於指定十進位數的最大整數值。

public:
 static System::Decimal Floor(System::Decimal d);
public static decimal Floor (decimal d);
static member Floor : decimal -> decimal
Public Shared Function Floor (d As Decimal) As Decimal

參數

d
Decimal

十進位數。

傳回

小於或等於 d的最大整數值。 請注意,方法會傳回類型為 Decimal的整數值。

範例

下列範例說明 Math.Floor(Decimal) 方法,並與 Ceiling(Decimal) 方法形成對比。

decimal[] values = {7.03m, 7.64m, 0.12m, -0.12m, -7.1m, -7.6m};
Console.WriteLine("  Value          Ceiling          Floor\n");
foreach (decimal value in values)
   Console.WriteLine("{0,7} {1,16} {2,14}",
                     value, Math.Ceiling(value), Math.Floor(value));
// The example displays the following output to the console:
//         Value          Ceiling          Floor
//
//          7.03                8              7
//          7.64                8              7
//          0.12                1              0
//         -0.12                0             -1
//          -7.1               -7             -8
//          -7.6               -7             -8
// The ceil and floor functions may be used instead. 
let values = 
    [ 7.03m; 7.64m; 0.12m; -0.12m; -7.1m; -7.6m ]
printfn "  Value          Ceiling          Floor\n"
for value in values do
    printfn $"{value,7} {Math.Ceiling value,16} {Math.Floor value,14}"
// The example displays the following output to the console:
//         Value          Ceiling          Floor
//
//          7.03                8              7
//          7.64                8              7
//          0.12                1              0
//         -0.12                0             -1
//          -7.1               -7             -8
//          -7.6               -7             -8
Dim values() As Decimal = {7.03d, 7.64d, 0.12d, -0.12d, -7.1d, -7.6d}
Console.WriteLine("  Value          Ceiling          Floor")
Console.WriteLine()
For Each value As Decimal In values
   Console.WriteLine("{0,7} {1,16} {2,14}", _
                     value, Math.Ceiling(value), Math.Floor(value))
Next   
' The example displays the following output to the console:
'         Value          Ceiling          Floor
'       
'          7.03                8              7
'          7.64                8              7
'          0.12                1              0
'         -0.12                0             -1
'          -7.1               -7             -8
'          -7.6               -7             -8

備註

此方法的行為遵循 IEEE Standard 754 第 4 節。 這種四捨五入有時稱為向負無限四捨五入。 換句話說,如果 d 為正數,則會截斷任何小數部分。 如果 d 為負數,則任何小數部分的存在會使它四捨五入為較小的整數。 此方法的作業與 Ceiling 方法不同,此方法支援向正無限四捨五入。

另請參閱

適用於

Floor(Double)

來源:
Math.cs
來源:
Math.cs
來源:
Math.cs

傳回小於或等於指定雙精確度浮點數的最大整數值。

public:
 static double Floor(double d);
public static double Floor (double d);
static member Floor : double -> double
Public Shared Function Floor (d As Double) As Double

參數

d
Double

雙精確度浮點數。

傳回

小於或等於 d的最大整數值。 如果 d 等於 NaNNegativeInfinityPositiveInfinity,則會傳回該值。

範例

下列範例說明 Math.Floor(Double) 方法,並與 Ceiling(Double) 方法形成對比。

double[] values = {7.03, 7.64, 0.12, -0.12, -7.1, -7.6};
Console.WriteLine("  Value          Ceiling          Floor\n");
foreach (double value in values)
   Console.WriteLine("{0,7} {1,16} {2,14}",
                     value, Math.Ceiling(value), Math.Floor(value));
// The example displays the following output to the console:
//         Value          Ceiling          Floor
//
//          7.03                8              7
//          7.64                8              7
//          0.12                1              0
//         -0.12                0             -1
//          -7.1               -7             -8
//          -7.6               -7             -8
// The ceil and floor functions may be used instead.
let values = 
    [ 7.03; 7.64; 0.12; -0.12; -7.1; -7.6 ]
printfn "  Value          Ceiling          Floor\n"
for value in values do
    printfn $"{value,7} {Math.Ceiling value,16} {Math.Floor value,14}"
// The example displays the following output to the console:
//         Value          Ceiling          Floor
//
//          7.03                8              7
//          7.64                8              7
//          0.12                1              0
//         -0.12                0             -1
//          -7.1               -7             -8
//          -7.6               -7             -8
Dim values() As Double = {7.03, 7.64, 0.12, -0.12, -7.1, -7.6}
Console.WriteLine("  Value          Ceiling          Floor")
Console.WriteLine()
For Each value As Double In values
   Console.WriteLine("{0,7} {1,16} {2,14}", _
                     value, Math.Ceiling(value), Math.Floor(value))
Next   
' The example displays the following output to the console:
'         Value          Ceiling          Floor
'       
'          7.03                8              7
'          7.64                8              7
'          0.12                1              0
'         -0.12                0             -1
'          -7.1               -7             -8
'          -7.6               -7             -8

備註

此方法的行為遵循 IEEE Standard 754 第 4 節。 這種四捨五入有時稱為向負無限四捨五入。 換句話說,如果 d 為正數,則會截斷任何小數部分。 如果 d 為負數,則任何小數部分的存在會使它四捨五入為較小的整數。 此方法的作業與 Ceiling 方法不同,此方法支援向正無限四捨五入。

從 Visual Basic 15.8 開始,如果您將 方法傳回的值傳遞給的任何 整數轉換函式,或 傳回的 Double 值會自動轉換成 Option Strict 設定為 Off 的整數,則雙整數轉換的效能會優化。 此優化可讓程式代碼執行得更快-- 對執行大量轉換至整數類型的程式代碼,最多兩倍的速度。 下列範例說明這類優化的轉換:

Dim d1 As Double = 1043.75133
Dim i1 As Integer = CInt(Math.Floor(d1))        ' Result: 1043

Dim d2 As Double = 7968.4136
Dim i2 As Integer = CInt(Math.Floor(d2))        ' Result: 7968

另請參閱

適用於