我知道这个问题~有点无厘头和傻乎乎。还是想请人解答一下~
----------可能目前脑子正处于抽风阶段----------
首先,我知道int占4个字节,包含正负2的31次方内的数字,也就是基本可以表示10位数字。
那么根据Ascll里,一个数字占用一个字节的规则来思考。
我让int按照这种规则来储存数字,是不是应该只能储存最多4位数字???
还请明白人~指出我这样思考的错误点在哪里?或者告知正确的解答方式~。
和楼上的想法基本差不多。
首先这是两个概念,在我看来,一个表示存储,而另一个表示展示。
例如:我们都知道boolean类型,同样的值,在某些情况下,可以表示为1、0,也可以表示为true、false。
楼主的意识误区在于概念中的错误。
首先我们来分析下楼主的逻辑,再找出其中的错误:
∵ ① int = 4 字节; ② Ascll里,1数字 = 1字节 ∴ int = 4 数字 从而推导出 int 最多储存4位数字。
我们可以看出,条件②是错误,所以得到的答案是错误的
分析:
1数字 = 1字节,那么1字节 = 1 数字么?
我们可以说,在某些情况下是相等的, 就是在 256 进制下,而楼主却用10进制来套256进制,所以错了
为什么是256进制?是因为1字节可以表示0-255之间的任意数值,所以 int 最多存储4位 256位进制的数字
综上所述,楼主的话在某些情况下是对的,但需要加一个前提,就是 256 进制的数字
int = 4字节(Byte),而不是4比特位(bit)
1字节 = 8比特位(bit)
1个比特位 = 0或者1
1个字节 = 0-255
而现实生活中的十进制:
一位十进制 = 0-9
满10进1
二进制也是一样的
1bit = 0-1
满1进1
一个int 0 的二进制是: 00000000000000000000000000000000
+1的结果是啊: 00000000000000000000000000000001
再+1的结果是: 00000000000000000000000000000010
再+1的结果是: 00000000000000000000000000000100
再+1000: 00000000000000000000001111101011