Math.Floor Método
Definición
Devuelve el mayor valor integral menor o igual que el número especificado.Returns the largest integral value less than or equal to the specified number.
Sobrecargas
| Floor(Double) |
Devuelve el mayor valor integral menor o igual que el número de punto flotante de precisión doble especificado.Returns the largest integral value less than or equal to the specified double-precision floating-point number. |
| Floor(Decimal) |
Devuelve el mayor valor integral menor o igual que el número decimal especificado.Returns the largest integral value less than or equal to the specified decimal number. |
Comentarios
El comportamiento de este método sigue el estándar IEEE 754, sección 4.The behavior of this method follows IEEE Standard 754, section 4. Este tipo de redondeo a veces se denomina redondeo hacia el infinito negativo.This kind of rounding is sometimes called rounding toward negative infinity.
Floor(Double)
Devuelve el mayor valor integral menor o igual que el número de punto flotante de precisión doble especificado.Returns the largest integral value less than or equal to the specified double-precision floating-point number.
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
Parámetros
- d
- Double
Número de punto flotante de precisión doble.A double-precision floating-point number.
Devoluciones
El mayor valor integral que es menor o igual que d.The largest integral value less than or equal to d. Si d es igual que NaN, NegativeInfinity o PositiveInfinity, se devuelve ese valor.If d is equal to NaN, NegativeInfinity, or PositiveInfinity, that value is returned.
Ejemplos
En el ejemplo siguiente se muestra el Math.Floor(Double) método y se contrasta con el Ceiling(Double) método.The following example illustrates the Math.Floor(Double) method and contrasts it with the Ceiling(Double) method.
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
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
Comentarios
El comportamiento de este método sigue el estándar IEEE 754, sección 4.The behavior of this method follows IEEE Standard 754, section 4. Este tipo de redondeo a veces se denomina redondeo hacia el infinito negativo.This kind of rounding is sometimes called rounding toward negative infinity. En otras palabras, si d es positivo, se trunca cualquier componente fraccionario.In other words, if d is positive, any fractional component is truncated. Si d es negativo, la presencia de cualquier componente fraccionario hace que se redondee al entero más pequeño.If d is negative, the presence of any fractional component causes it to be rounded to the smaller integer. La operación de este método difiere del Ceiling método, que admite el redondeo hacia el infinito positivo.The operation of this method differs from the Ceiling method, which supports rounding toward positive infinity.
A partir de Visual Basic 15,8, se optimiza el rendimiento de la conversión de doble a entero si se pasa el valor devuelto por el Floor método a cualquiera de las funciones de conversión integral, o si el valor Double devuelto por Floor se convierte automáticamente en un entero con Option Strict establecida en OFF.Starting with Visual Basic 15.8, the performance of Double-to-integer conversion is optimized if you pass the value returned by the Floor method to the any of the integral conversion functions, or if the Double value returned by Floor is automatically converted to an integer with Option Strict set to Off. Esta optimización permite que el código se ejecute más rápido, hasta el doble de rápido para código que realiza un gran número de conversiones a tipos enteros.This optimization allows code to run faster -- up to twice as fast for code that does a large number of conversions to integer types. En el ejemplo siguiente se muestran estas conversiones optimizadas:The following example illustrates such optimized conversions:
Dim d1 As Double = 1043.75133
Dim i1 As Integer = CInt(Math.Ceiling(d1)) ' Result: 1043
Dim d2 As Double = 7968.4136
Dim i2 As Integer = CInt(Math.Ceiling(d2)) ' Result: 7968
Consulte también
Se aplica a
Floor(Decimal)
Devuelve el mayor valor integral menor o igual que el número decimal especificado.Returns the largest integral value less than or equal to the specified decimal number.
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
Parámetros
- d
- Decimal
Número decimal.A decimal number.
Devoluciones
El mayor valor integral que es menor o igual que d.The largest integral value less than or equal to d. Tenga en cuenta que el método devuelve un valor entero de tipo Decimal.Note that the method returns an integral value of type Decimal.
Ejemplos
En el ejemplo siguiente se muestra el Math.Floor(Decimal) método y se contrasta con el Ceiling(Decimal) método.The following example illustrates the Math.Floor(Decimal) method and contrasts it with the Ceiling(Decimal) method.
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
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
Comentarios
El comportamiento de este método sigue el estándar IEEE 754, sección 4.The behavior of this method follows IEEE Standard 754, section 4. Este tipo de redondeo a veces se denomina redondeo hacia el infinito negativo.This kind of rounding is sometimes called rounding toward negative infinity. En otras palabras, si d es positivo, se trunca cualquier componente fraccionario.In other words, if d is positive, any fractional component is truncated. Si d es negativo, la presencia de cualquier componente fraccionario hace que se redondee al entero más pequeño.If d is negative, the presence of any fractional component causes it to be rounded to the smaller integer. La operación de este método difiere del Ceiling método, que admite el redondeo hacia el infinito positivo.The operation of this method differs from the Ceiling method, which supports rounding toward positive infinity.