谁能给我解释一下(详细)如何将两个__int64 objs相乘并检查结果是否适合__int64。
注意:不要使用任何编译器或处理器相关的例程。
不假设a
和b
为正:
__int64 a,b;
//...
__int64 tmp_result = abs(a) * abs(b) ;
if (
( a && b ) &&
(
( tmp_result < abs(a) || tmp_result < abs(b) ) ||
( tmp_result / abs(a) != abs(b)) ||
( a == TYPE_MIN && b != 1) ||
( b == TYPE_MIN && a != 1)
)
)
std::cout << "overflow";
__int64 result = a * b;
EDIT:为代码添加角落案例。
EDIT:我认为只要( a && a * b / a != b)
就足够了。