一、Java中数据类型
主要分为两类:基本数据类型和引用数据类型。
基本数据类型有四类八种:
- 四类:整型、浮点型、字符型以及布尔型
- 八种:
其上所对应的Java包装类型有8种,分别是:1、Byte;2、Short;3、Integer;4、Long;5、Float;6、Double;7、Character,8、Boolean
注意:
(1)不论是在16位系统还是32位系统,上述所占字节数不变
(2)整形和浮点型都是带有符号的(没有无符号类型)
(3)整型默认为int型,浮点型默认为double
(4)字符串属于引用类型
(5)char为2字节,可以用来显示一个汉字字符
为什么整形范围符数比正数多一个呢?(以短整形为例short)
符号位
0 111 1111 1111 1111
1 111 1111 1111 1111
-215~215-1
这里有一个0值的差别。
0000 0000 0000 0000 (正零)
1000 0000 0000 0000 (负零)
从数学角度上,是没区别的,可是用两种形式表示一个数,明显是浪费了。
于是计算机存储就约定,当符号位为0,即正零时才是0.
符号位为1时,让它去表示另外一个数好了。
(上面这句话是重点,因为让它表示另外一个数,符号位就不少纯粹的符号位了,就代表符号位也会参与取反)
原码:1000 0000 0000 0000首先符号位为1,是个负数,
反码,0111 1111 1111 1111
补码,1000 0000 0000 0000
这时补码中的 1 代表的就是值了,而不是符号位了。
计算其值就是32768.又因为它是个负数,因此为-32768
- byte与byte的运算
byte a = 10;
byte b = 20;
byte c = a + b;
System.out.println©;
// 编译报错
Test.java:5: 错误: 不兼容的类型: 从int转换到byte可能会有损失
byte c = a + b;
结论: byte 和 byte 都是相同类型, 但是出现编译报错. 原因是, 虽然 a 和 b 都是 byte, 但是计算 a + b 会先将 a
和 b 都提升成 int, 再进行计算, 得到的结果也是 int, 这是赋给 c, 就会出现上述错误.
由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short
这种低于 4 个字节的类型, 会先提升成 int, 再参与计算.
正确的写法:
byte a = 10;
byte b = 20;
byte c = (byte)(a + b);
System.out.println©;