先来2段代码。
lj@lj-virtual-machine:~/111111/test$ ./a.out
-539222987
lj@lj-virtual-machine:~/111111/test$ cat mapan.cpp
#include <iostream>
#include <stdint.h>
using namespace std;
int64_t test()
{
int a = 1234567890;
return a * 10 + 1;
}
int main() {
cout << test() << endl;
return 0;
}
-539222987是代码直接的结果,显然和预期不符。
lj@lj-virtual-machine:~/111111/test$ ./a.out
12345678901
lj@lj-virtual-machine:~/111111/test$ cat mapan.cpp
#include <iostream>
#include <stdint.h>
using namespace std;
int64_t test()
{
int a = 1234567890;
return a * (int64_t)10 + 1;
}
int main() {
cout << test() << endl;
return 0;
}
12345678901是代码执行的结果,这个结果显示符合预期。
两段代码的差别是(int64_t),a*10产生了溢出,a*10的结果虽然没有赋值给a(a*10的结果现然超过int的范围),但是a*10的结果保存在一个临时的整数里,(int64_t)相当于给这个临时的整数分配int64_t这个类型大小的空间,才没有导致溢出,最后结果正确。