?
This document uses PHP Chinese website manual Release
在頭文件<math.h>中定義 | ||
---|---|---|
float truncf(float arg); | (1) | (自C99以來) |
double trunc(double arg); | (2) | (自C99以來) |
long double truncl(long double arg); | (3) | (自C99以來) |
在頭文件<tgmath.h>中定義 | ||
#define trunc(arg) | (4) | (自C99以來) |
1-3)計算量值不大于arg的最近整數(shù)。
4)類型 - 泛型宏:如果arg的類型為long double,則調(diào)用truncl。 否則,如果arg具有整數(shù)類型或double類型,則調(diào)用trunc。 否則,truncf被調(diào)用。
ARG | - | 浮點值 |
---|
如果沒有發(fā)生錯誤,則返回量值不大于arg的最接近的整數(shù)值(換句話說,arg舍入為零)。
返回值
討論
按照math_errhandling中的指定報告錯誤。
如果實現(xiàn)支持IEEE浮點運算(IEC 60559),
當(dāng)前的舍入模式不起作用。
如果arg
是±∞,則返回,未修改
如果arg
為±0,則返回,未修改
如果arg是NaN,則返回NaN
FE_INEXACT
在截斷非整數(shù)有限值時可能(但不是必須))。
最大的可表示浮點值是所有標(biāo)準(zhǔn)浮點格式中的精確整數(shù),因此該函數(shù)不會自行溢出; 但是intmax_t
當(dāng)存儲在整數(shù)變量中時,結(jié)果可能會溢出任何整數(shù)類型(包括)。
從浮點型到整型類型的隱式轉(zhuǎn)換也向零舍入,但僅限于可由目標(biāo)類型表示的值。
#include <math.h>#include <stdio.h>int main(void){ printf("trunc(+2.7) = %+.1f\n", trunc(2.7)); printf("trunc(-2.7) = %+.1f\n", trunc(-2.7)); printf("trunc(-0.0) = %+.1f\n", trunc(-0.0)); printf("trunc(-Inf) = %+f\n", trunc(-INFINITY));}
可能的輸出:
trunc(+2.7) = +2.0trunc(-2.7) = -2.0trunc(-0.0) = -0.0trunc(-Inf) = -inf
C11標(biāo)準(zhǔn)(ISO / IEC 9899:2011):
7.12.9.8截斷函數(shù)(p:253-254)
7.25類型通用數(shù)學(xué)<tgmath.h>(p:373-375)
F.10.6.8截斷函數(shù)(p:528)
C99標(biāo)準(zhǔn)(ISO / IEC 9899:1999):
7.12.9.8截斷函數(shù)(p:234)
7.22類型通用數(shù)學(xué)<tgmath.h>(p:335-337)
F.9.6.8 trunc函數(shù)(p:464)
floorfloorphloorl(C99)(C99) | 計算不大于給定值的最大整數(shù)(函數(shù)) |
---|---|
ceilceilfceill(C99)(C99) | 計算不小于給定值的最小整數(shù)(函數(shù)) |
roundlroundllround(C99)(C99)(C99) | 舍入到最接近的整數(shù),在中途情況下從零開始舍去(函數(shù)) |
| trunc的C ++文檔 |