java_learning|Java中的数据类型

目录
一、int
二、long
三、double
四、float
五、char
六、byte与short
一、int 还记得 C 语言里的 int 吗,C里面的 int 有着无符号与有符号之分
但是Java内就没有,且固定占4个字节大小,也就是32比特位
因为没有符号之分,所以第一位默认是符号位
所以剩下的31位来存二进制数据
java_learning|Java中的数据类型
文章图片

一个int所能表示范围就是 -2^31 -> 2^31-1
在java内,我们可以看到每个基本类型的范围:

System.out.println(Integer.MAX_VALUE); //最大值 System.out.println(Integer.MIN_VALUE); //最小值

java_learning|Java中的数据类型
文章图片

但是仅有21亿怎么能满足呢,我们需要用long来体现。

二、long Java中 long 与 C语言 的区别在以下几点:
Java中 long 占 8字节,C占 4字节
在Java中定义long类型时,要在数字后加上L
long n = 10L;

小写的L也行,但为了与1区别开来,更加醒目。
8个字节也就是64比特位,第一位符号位,范围也就来到了惊人的-2^63 -> 2^63-1
同样我们也可以来看看 long 的范围:
System.out.println(Long.MAX_VALUE); System.out.println(Long.MIN_VALUE);

java_learning|Java中的数据类型
文章图片

这个值我觉得可以满足我们的使用了,但是小数问题呢?

三、double 来道易错题:
int m = 1; int n = 2; System.out.println(m / n);

此结果为0,因为万恶的 1.0 与 1 在编程的世界里是不一样的。
那我这样写呢?
int m = 1.0; int n = 2.0; System.out.println(m / n);

这样子系统会认为1.0是8字节的double,不能存入仅有4字节的int内,于是直接报错。
正确写法:
double m = 1.0; double n = 2.0; System.out.println(m / n);

让我们再看个代码:
double n = 1.2; System.out.println(n * n);

java_learning|Java中的数据类型
文章图片

为什么在末尾会有个神奇的 '2' ?
因为 double 在内存中的存储方式遵从IEEE754标准,与整数不同,存在误差。

四、float Java中的 float 的注意点主要有两个:
1. 在定义float类型变量时,同 long 类型一样,要在数字末尾加上 f 或 F, 与 double 来区分。
float n = 1.1f;

2. float 作为单精度浮点数,只能保留小数点后六位的数,精度较小。

五、char 在 Java 中,char 与 C的区别就很大:
1. 由于Java支持Unicode编码,所以Java的char你甚至可以表示中文
char q = '哈'; System.out.println(q);

java_learning|Java中的数据类型
文章图片

2. 因为能表示中文,所以char类型占了2个字节 (这也是最大的区别,要注意)
也就意味着 char 的范围也扩大了。

六、byte与short 这两个都是表示整数,仅是范围不同而已。
byte 只占一个字节,所以范围仅有 -127 ~ 128
short 占两个字节,所以范围扩大为 -32768 -> 32767
虽然他们很小,但是省内存。看需求使用,选自己合适的最好。

未完待续。。。

【java_learning|Java中的数据类型】

    推荐阅读