bugprone-integer-division¶
查找在浮点上下文中的整数除法可能导致意外精度损失的情况。
如果除法是以下表达式的部分,则不会生成任何报告
需要整数或布尔类型的操作数的运算符,
整数或布尔类型的调用表达式,以及
显式转换为整数或布尔类型的表达式,
因为这些被解释为程序员的刻意行为。
示例
float floatFunc(float);
int intFunc(int);
double d;
int i = 42;
// Warn, floating-point values expected.
d = 32 * 8 / (2 + i);
d = 8 * floatFunc(1 + 7 / 2);
d = i / (1 << 4);
// OK, no integer division.
d = 32 * 8.0 / (2 + i);
d = 8 * floatFunc(1 + 7.0 / 2);
d = (double)i / (1 << 4);
// OK, there are signs of deliberateness.
d = 1 << (i / 2);
d = 9 + intFunc(6 * i / 32);
d = (int)(i / 32) - 8;