在头文件中定义float modff( float arg, float* iptr );(1)(since C99)
double modf( double arg, double* iptr );(2)
long double modfl( long double arg, long double* iptr );(3)(since C99)
1-3)将给定的浮点值分解arg为整数和小数部分,每部分具有相同的类型和符号arg。整数部分(浮点格式)存储在指向的对象中iptr。
参数
arg-浮点值iptr-指向浮点值来存储整数部分
返回值
如果没有错误发生,返回与小数部分x相同的符号x。积分部分被放入到所指的值中iptr。
返回的值和存储的值的和*iptr给出arg(允许舍入)。
错误处理
此函数不受在math_errhandling中指定的任何错误的影响。
如果实现支持IEEE浮点运算(IEC 60559),
如果arg是±0,则返回±0,并存储±0 *iptr。
如果arg是±∞,返回±0,并存储±∞ *iptr。
如果arg是NaN,则返回NaN,并存储NaN *iptr。
返回的值是精确的,当前舍入模式被忽略
笔记
该函数的行为如同执行如下:
double modf(double value, double *iptr){#pragma STDC FENV_ACCESS ON
int save_round = fegetround(); fesetround(FE_TOWARDZERO); *iptr = std::nearbyint(value);