临时整形变量溢出的问题

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ma2595162349/article/details/89928882

         先来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这个类型大小的空间,才没有导致溢出,最后结果正确。

猜你喜欢

转载自blog.csdn.net/ma2595162349/article/details/89928882