Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Zaokrouhlí hodnotu s plovoucí desetinou čárkou na nejbližší celé číslo ve formátu s plovoucí desetinou čárkou.
Syntaxe
double rint( double x );
float rintf( float x );
long double rintl( long double x );
#define rint(X) // Requires C11 or later
float rint( float x ); // C++ only
long double rint( long double x ); // C++ only
Parametry
x
Hodnota s plovoucí desetinou čárkou, která se má zaokrouhlit.
Vrácená hodnota
Funkce rint vrátí hodnotu s plovoucí desetinou čárkou, která představuje nejbližší celé číslo .x Hodnoty v polovině se zaokrouhlují podle aktuálního nastavení režimu zaokrouhlování s plovoucí desetinou čárkou, stejně jako funkce nearbyint . nearbyint Na rozdíl od funkcí mohou funkce vyvolat FE_INEXACT výjimku s plovoucí desetinou čárkou, rint pokud se výsledek liší v hodnotě od argumentu. Nevrátí se žádná chyba.
| Vstup | Výjimka SEH | Výjimka _matherr |
|---|---|---|
| ± INF, QNaN, IND | Žádná | Žádná |
| Denormals | EXCEPTION_FLT_UNDERFLOW |
Žádná |
Poznámky
Vzhledem k tomu, že jazyk C++ umožňuje přetížení, můžete volat přetížení rint tohoto převzetí a vrácení float a long double hodnoty. Pokud v programu jazyka C nepoužíváte <makro tgmath.h> k volání této funkce, rint vždy přebírá a vrací hodnotu double.
Pokud použijete <makro tgmath.h>rint() , typ argumentu určuje, která verze funkce je vybrána. Podrobnosti najdete v tématu Matematika pro obecné typy.
Ve výchozím nastavení je globální stav této funkce vymezen na aplikaci. Chcete-li toto chování změnit, přečtěte si téma Globální stav v CRT.
Požadavky
| Function | Záhlaví jazyka C | Hlavička jazyka C++ |
|---|---|---|
rint, , rintfrintl |
<math.h> | <cmath> |
rint makro |
<tgmath.h> |
Další informace o kompatibilitě najdete v tématu Kompatibilita.
Příklad
// 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));
}
rint(2.499999) is 2
rint(-2.499999) is -2
rintf(2.800000) is 3
rintf(-2.800000) is -3
rintl(2.500000) is 3
rintl(-2.500000) is -3
Viz také
Podpora pro matematiku a plovoucí desetinou čárku
ceil, , ceilfceill
floor, , floorffloorl
fmod, fmodf
lrint, lrintf, lrintl, llrint, , llrintfllrintl
lround, lroundf, lroundl, llround, , llroundfllroundl
nearbyint, , nearbyintfnearbyintl
rint