?
Ce document utilise Manuel du site Web PHP chinois Libérer
在頭文件<math.h>中定義 | ||
---|---|---|
float floorf( float arg ); | (1) | (自 C99) |
double floor( double arg ); | (2) | |
long double floorl( long double arg ); | (3) | (自 C99) |
在頭文件 <tgmath.h>中定義 | ||
#define floor( arg ) | (4) | (自 C99) |
1-3)計(jì)算不大于arg的最大整數(shù)值。
4)類型 - 通用宏:如果arg的類型為long double,則稱為floorl。 否則,如果arg具有整數(shù)類型或類型double,則調(diào)用floor。 否則,floorf被調(diào)用。
arg | - | floating point value |
---|
如果沒有發(fā)生錯(cuò)誤,則返回不大于arg的最大整數(shù)值,即?arg?。
返回值
看法
按照math_errhandling中的指定報(bào)告錯(cuò)誤。
如果實(shí)現(xiàn)支持IEEE浮點(diǎn)運(yùn)算(IEC 60559),
當(dāng)前的舍入模式不起作用。
如果arg為±∞,則返回,未修改
如果arg為±0,則返回,未修改
如果arg是NaN,則返回NaN
在四舍五入非整數(shù)有限值時(shí),F(xiàn)E_INEXACT可能(但不是必須)引發(fā)。
最大的可表示浮點(diǎn)值是所有標(biāo)準(zhǔn)浮點(diǎn)格式中的精確整數(shù),因此該函數(shù)不會(huì)自行溢出; 但是當(dāng)存儲(chǔ)在整型變量中時(shí),結(jié)果可能會(huì)溢出任何整數(shù)類型(包括intmax_t)。
#include <math.h>#include <stdio.h>int main(void){ printf("floor(+2.7) = %+.1f\n", floor(2.7)); printf("floor(-2.7) = %+.1f\n", floor(-2.7)); printf("floor(-0.0) = %+.1f\n", floor(-0.0)); printf("floor(-Inf) = %+f\n", floor(-INFINITY));}
可能的輸出:
floor(+2.7) = +2.0floor(-2.7) = -3.0floor(-0.0) = -0.0floor(-Inf) = -inf
C11標(biāo)準(zhǔn)(ISO / IEC 9899:2011):
7.12.9.2 floor 功能(p:251)
7.25類型通用數(shù)學(xué)<tgmath.h>(p:373-375)
F.10.6.2 floor 功能(p:526)
C99標(biāo)準(zhǔn)(ISO / IEC 9899:1999):
7.12.9.2 floor 功能(p:232)
7.22類型通用數(shù)學(xué)<tgmath.h>(p:335-337)
F.9.6.2 floor 功能(p:463)
C89 / C90標(biāo)準(zhǔn)(ISO / IEC 9899:1990):
4.5.6.3 floor 功能
ceilceilfceill(C99)(C99) | 計(jì)算不小于給定值的最小整數(shù)(函數(shù)) |
---|---|
trunctruncftruncl(C99)(C99)(C99) | 四舍五入到最接近的整數(shù),其大小不超過給定值(函數(shù)) |
roundlroundllround(C99)(C99)(C99) | 舍入到最接近的整數(shù),在中途情況下從零開始舍去(函數(shù)) |
| 用于floor的C ++文檔 |