计算过程中考虑溢出

记一记在计算过程中考虑溢出的情况:

就基本的内置数据类型来说,每一种类型都有固定的宽度,固定位数来表示数据对象。实际中,很有可能表示的数据会比能表示的范围更大,那么就会数据溢出了。

谨记,已经溢出的数据我们是毫无办法的,因为它已经成为了一个错误的可表示范围内的数据,但是在一个不断操作过程中可能发生溢出的话,我们可以先判断,再继续操作,以防它溢出,当且仅当不会溢出时我们才继续计算,以保证数据的安全。总之就是,为了保证数据的安全,已经溢出的数据我们并不能判别,那么就在操作之前判别操作之后是否会溢出。比如:X += 1000;不知道x加操作后是否会溢出,那就先判断X是否小于INT_MAX-1000;如果安全,则再计算。

又如一个循环中:当然前提是之前的res就在可表示范围内,

   while(absx!=0)
        {
            if(res>(INT_MAX-absx%10)/10)
                return 0;
            res = res*10+absx%10;
            
            absx = absx/10;
        }

可以按照这样的方法以此判断最终结果是否溢出,但是一定谨记之前的数据就在可表示范围内,当然啦,负向的话通过INT_MIN来判断就可以了

原文地址:https://www.cnblogs.com/weiyi-mgh/p/6762664.html