C++ Builder 串口控件 | C++ Builder 编程技巧 | C++ Builder 操作指南 | C++ Builder 参考手册 | 基础知识 | cfloat 浮点数 | cmath 数学函数 | • acos, acosf, acosl | • acosh, acoshf, acoshl | • asin, asinf, asinl | • asinh, asinhf, asinhl | • atan, atanf, atanl | • atan2, atan2f, atan2l | • atanh, atanhf, atanhl | • ceil, ceilf, ceill | • copysign, copysignf, copysignl | • cos, cosf, cosl | • cosh, coshf, coshl | • exp, expf, expl | • exp2, exp2f, exp2l | • expm1, expm1f, expm1l | • fabs, fabsf, fabsl | • floor, floorf, floorl | • fmod, fmodf, fmodl | • frexp, frexpf, frexpl | • hypot, hypotf, hypotl | • ldexp, ldexpf, ldexpl | • log, logf, logl | • log10, log10f, log10l | • log1p, log1pf, log1pl | • log2, log2f, log2l | • modf, modff, modfl | • nan, nanf, nanl | • poly, polyl | • pow, powf, powl | • pow10, pow10l | • round, roundf, roundl | • sin, sinf, sinl | • sinh, sinhf, sinhl | • sqrt, sqrtf, sqrtl | • tan, tanf, tanl | • tanh, tanhf, tanhl | • trunc, truncf, truncl | • _exception, _exceptionl | • _matherr, _matherrl | • HUGE_VAL, HUGE_VALF, HUGE_VALL, _LHUGE_VAL | • EDOM, ERANGE | • _mexcep, DOMAIN, SING, OVERFLOW, UNDERFLOW, TLOSS, PLOSS, STACKFAULT | • M_E, M_LOG2E, M_LOG10E, M_LN2, M_LN10 | • M_PI, M_PI_2, M_PI_4, M_1_PI, M_2_PI, M_1_SQRTPI, M_2_SQRTPI | • M_SQRT2, M_SQRT_2 | • DOMAIN error 定义域错误 | cstdlib 标准库函数 | System 字符串 | System 日期和时间 | System.Math.hpp 数学函数 | 其他数据类型 | VCL 基础类 | VCL 应用程序 | Pictures 图片 | Graphics 绘图 | Additional 控件 | System 控件 | A ~ Z 字母顺序排列的目录 | 网友留言/技术支持 |
|
modf, modff, modfl - 把浮点数分解为小数部分和整数部分 |
函数原型:
函数原型 |
C90 |
C99 |
C++98 |
C++11 |
double modf(double x, double *y); |
√ |
√ |
√ |
√ |
float modff(float x, float *y); |
|
√ |
|
|
long double modfl(long double x, long double *y); |
|
√ |
|
|
float modf(float x, float *y); |
|
|
√ |
√ |
long double modf(long double x, long double *y); |
|
|
√ |
√ |
头文件:
#include <cmath>
命名空间:
std
参数:
x:浮点数,函数把这个数分解为小数部分和整数部分
y:浮点数指针,用于返回分解之后的整数部分
返回值:
返回值为 x 的小数部分,*y 为 x 的整数部分
例子:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
double Xes[] = { 12.34, -987.65, 5.43e50, -8.2e-20, (double)Infinity, (double)-Infinity };
UnicodeString s;
for(size_t i=0; i<sizeof(Xes)/sizeof(Xes[0]); i++)
{
double x = Xes[i];
double y;
double w = std::modf(x, &y);
Memo1->Lines->Add(s.sprintf(L"%9g 的整数部分: %9g, 小数部分: %9g", x, y, w));
}
} |
兼容性:
相关链接:
• fmod • ceil • floor • round • trunc • RoundTo • _matherr • 浮点数异常处理
|
|
|
|