rint, rintf, rintl
Arrotonda un valore a virgola mobile all'intero più vicino nel formato a virgola mobile.
double rint( double x );
float rint( float x ); // C++ only
long double rint( long double x ); // C++ only
float rintf( float x );
long double rintl( long double x );
Parametri
- x
Valore a virgola mobile da arrotondare.
Valore restituito
Le funzioni rint restituiscono un valore a virgola mobile che rappresenta l'intero più vicino a x. I valori a metà vengono arrotondati in base alle attuali impostazioni per la modalità di arrotondamento a virgola mobile, come accade con le funzioni nearbyint. A differenza delle funzioni nearbyint, le funzioni rint possono generare l'eccezione di virgola mobile FE_INEXACT se il risultato è diverso dall'argomento in termini di valore. Non vi è restituzione di errori.
Input |
Eccezione SEH |
Eccezione _matherr |
---|---|---|
± ∞, QNAN, IND |
nessuno |
nessuno |
Valori denormalizzati |
EXCEPTION_FLT_UNDERFLOW |
nessuno |
Note
Dato che C++ consente l'overload, è possibile chiamare degli overload di rint che accettino e restituiscano valori float e long double. In un programma C rint accetta e restituisce sempre un valore double.
Requisiti
Funzione |
Intestazione C |
Intestazione C++ |
---|---|---|
rint, rintf, rintl |
<math.h> |
<cmath> |
Per altre informazioni sulla compatibilità, vedere Compatibilità.
Esempio
// crt_rint.c
// Build with: cl /W3 /Tc crt_rint.c
// This example displays the rounded results of
// the floating-point values 2.499999, -2.499999,
// 2.8, -2.8, 2.5 and -2.5.
#include <math.h>
#include <stdio.h>
int main( void )
{
double x = 2.499999;
float y = 2.8f;
long double z = 2.5;
printf("rint(%f) is %.0f\n", x, rint (x));
printf("rint(%f) is %.0f\n", -x, rint (-x));
printf("rintf(%f) is %.0f\n", y, rintf(y));
printf("rintf(%f) is %.0f\n", -y, rintf(-y));
printf("rintl(%Lf) is %.0Lf\n", z, rintl(z));
printf("rintl(%Lf) is %.0Lf\n", -z, rintl(-z));
}
Equivalente .NET Framework
Vedere anche
Riferimenti
lround, lroundf, lroundl, llround, llroundf, llroundl