?
This document uses PHP Chinese website manual Release
在頭文件<math.h>中定義 | ||
---|---|---|
float ceilf( float arg ); | (1) | (since C99) |
double ceil( double arg ); | (2) | |
long double ceill( long double arg ); | (3) | (since C99) |
Defined in header <tgmath.h> | ||
#define ceil( arg ) | (4) | (since C99) |
1-3)計算不小于的最小整數(shù)值arg
。
4)類型 - 通用宏:如果arg
有類型long double
,ceill
被調(diào)用。否則,如果arg
有整數(shù)類型或類型double
,ceil
則調(diào)用。否則,ceilf
被調(diào)用。
arg | - | 浮點(diǎn)值 |
---|
如果沒有發(fā)生錯誤arg
,則返回不小于的最小整數(shù)值,即?arg?。
返回值
論據(jù)
按照math_errhandling中的指定報告錯誤。
如果實現(xiàn)支持IEEE浮點(diǎn)運(yùn)算(IEC 60559),
當(dāng)前的舍入模式不起作用。
如果arg
是±∞,則返回,未修改
如果arg
為±0,則返回,未修改
如果arg是NaN,則返回NaN
FE_INEXACT
在舍入非整數(shù)有限值時可能(但不是必須))。
最大的可表示浮點(diǎn)值是所有標(biāo)準(zhǔn)浮點(diǎn)格式中的精確整數(shù),因此該函數(shù)不會自行溢出; 但是intmax_t
,當(dāng)存儲在整數(shù)變量中時,結(jié)果可能會溢出任何整數(shù)類型(包括)。
這個函數(shù)(用于雙參數(shù))的行為就像(FE_INEXACT
由不執(zhí)行的自由除外)一樣。
#include <math.h>#include <fenv.h>#pragma STDC FENV_ACCESS ON double ceil(double x){ double result; int save_round = fegetround(); fesetround(FE_UPWARD); result = rint(x); // or nearbyint fesetround(save_round); return result;}
#include <math.h>#include <stdio.h>int main(void){ printf("ceil(+2.4) = %+.1f\n", ceil(2.4)); printf("ceil(-2.4) = %+.1f\n", ceil(-2.4)); printf("ceil(-0.0) = %+.1f\n", ceil(-0.0)); printf("ceil(-Inf) = %+f\n", ceil(-INFINITY));}
可能的輸出:
ceil(+2.4) = +3.0ceil(-2.4) = -2.0ceil(-0.0) = -0.0ceil(-Inf) = -inf
C11標(biāo)準(zhǔn)(ISO / IEC 9899:2011):
7.12.9.1細(xì)胞功能(p:251)
7.25類型通用數(shù)學(xué)<tgmath.h>(p:373-375)
F.10.6.1 ceil函數(shù)(p:526)
C99標(biāo)準(zhǔn)(ISO / IEC 9899:1999):
7.12.9.1細(xì)胞功能(p:231-232)
7.22類型通用數(shù)學(xué)<tgmath.h>(p:335-337)
F.9.6.1 ceil函數(shù)(p:462-463)
C89 / C90標(biāo)準(zhǔn)(ISO / IEC 9899:1990):
4.5.6.1 ceil函數(shù)