| 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 字母顺序排列的目录 | | 网友留言/技术支持 |
|
| fmod, fmodf, fmodl - 求余数,返回值 = 被除数 - 商的整数部分 * 除数 |
函数原型:
| 函数原型 |
C90 |
C99 |
C++98 |
C++11 |
| double fmod(double x, double y); |
√ |
√ |
√ |
√ |
| float fmodf(float x, float y); |
|
√ |
|
|
| long double fmodl(long double x, long double y); |
|
√ |
|
|
| float fmod(float x, float y); |
|
|
√ |
√ |
| long double fmod(long double x, long double y); |
|
|
√ |
√ |
头文件:
#include <cmath>
命名空间:
std
参数:
x:被除数,y:除数,定义域范围为 x ∈ [-Infinity, +Infinity],y ∈ [-Infinity, +Infinity],x 和 y 不能同时为 0
返回值:
x ÷ y 的余数,返回值 = 被除数 - 商的整数部分 * 除数,即 x - trunc(x/y) * y
NAN:定义域错误,此时全局变量 errno 的值为 EDOM。
计算可能会溢出,此时全局变量 errno 的值为 ERANGE。
例子:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
Memo1->Lines->Add(L"fmod(12.34, 5.6) = " + FloatToStr(std::fmod(12.34, 5.6)));
Memo1->Lines->Add(L"fmod(-6.5 , 1.5) = " + FloatToStr(std::fmod(-6.5 , 1.5)));
Memo1->Lines->Add(L"fmod( 0.0 , 0.0) = " + FloatToStr(std::fmod( 0.0 , 0.0)));
} |
12.34 ÷ 5.6 = 2.20357142857143
2.20357142857143 取整数部分 2
12.34 - 5.6 × 2 = 12.34 - 11.2 = 1.14

兼容性:
| 函数 \ C++ Builder 编译器 |
bcc32 |
clang32 |
clang64 |
| fmod |
√ |
√ |
√ |
| fmodf |
|
版本 ≥ 10.2 Tokyo Update 1 |
√ |
| fmodl |
√ |
√ |
√ |
相关链接:
• modf • div • _matherr • 浮点数异常处理
|
|
|
|