u3t8:编写一个程序,用循环不停地输出2的倍数,观察最终会发生什么情况。
我写的代码如下:
#include <stdio.h>
int main()
{
int i;
for(i=1;;i++)
printf("%d\n",2*i);
return 0;
}
运行的时候很正常,似乎可以无穷地跑下去
可是这已经超过了int的范围了呀!为什么还能进行下去呢?是发生了隐式类型转换吗?不然的话,凭int类型有限的存储空间,怎么能存下这么大的数字呢?
已解决:大多数系统int类型占4个字节,32位;而不是2个字节,16位。
因此整数的最大值位2^31-1(与long相同~)