int介绍
int 类型通常占用 4 个字节,可以表示的整数范围为 -2147483648 ~ 2147483647
如果尝试将一个大于 int 类型的最大值的整数分配给一个 int 变量,将会导致溢出错误。
int num = 2147483647;
num += 1;
Console.WriteLine(num);//输出-2147483648
int溢出变负数
在计算机内部,整数类型(包括 int)是以二进制形式存储的。在 int 类型中,通常使用 4 个字节(32 位)来存储整数值。其中,最高位表示符号位,0 表示正数,1 表示负数。
当一个 int 类型的变量超过它所能表示的最大值时,二进制数位会从最大值开始递增,直到超出 32 位的范围,然后从头开始重新计数。这就是所谓的溢出现象。
在 int 类型中,当溢出后二进制数位到达最高位(即符号位)时,由于符号位为 1,表示负数,所以这个溢出的值就被解释为一个负数。这就是为什么 int 类型的溢出值通常会被解释为负数的原因。
例如,如果使用 int 类型来存储一个数值 2147483647,它是 int 类型的最大值,二进制表示为 01111111 11111111 11111111 11111111。如果再将这个值加 1,则二进制表示为 10000000 00000000 00000000 00000000,这个值超出了 int 类型能表示的范围,因此会溢出,而由于最高位为 1,表示负数,所以这个溢出值会被解释为 -2147483648,即 int 类型的最小值。