这里造成数据溢出

造成负数的原因
原码、反码和补码的资料,十进制数字存储在计算机时要转换为二进制。数字在累加的时候会不断进位,超过最大范围时符号位就变成了1,1表示的是负数,计算机就理解成这是个负数了

java各种类型的数据范围
long(长整型)的数据范围:-9223372036854775808——9223372036854775807;
int(整型)的数据范围:-2147483648——2147483647;
short(短整型):-32768——32767;
byte(位):-128——127;
char(字符型):0——65536;
float(单精度浮点型):-3.4E38(-3.4X10的38次方)——3.4E38(3.4X10的38次方);
double(双精度浮点型):-1.7E38——1.7E38;
public static void main(String args []){
int a = 2147483647;//定义一个int型变量a的值为int型能够保存的最高值
System.out.println(a + 1);
}
解决办法(换成long)
public static String a(){
long count = 0;
int a = 1000000;
for (int i = 0; i < a; i++) {
for (int j = 0; j < a; j++) {
count++;
}
}
return String.valueOf(count);
}
本文探讨了数据溢出问题,特别是在Java中进行整数运算时,当数值超过其数据类型的存储范围,导致符号位翻转,从而产生负数。例如,int类型的范围是-2^31到2^31-1,当超过这个范围时,计算结果可能会变成负数。示例代码展示了当试图将int的最大值加1时,如何引发溢出。解决方案是使用更大的数据类型如long来避免此类问题。同时,文章还列举了Java中不同数据类型的范围,帮助读者理解每种类型的适用场景。
72

被折叠的 条评论
为什么被折叠?



