Java数据类型的全面剖析
作者:丶chuchu丶
一、int
还记得 C 语言里的 int 吗,C里面的 int 有着无符号与有符号之分
但是Java内就没有,且固定占4个字节大小,也就是32比特位
因为没有符号之分,所以第一位默认是符号位
所以剩下的31位来存二进制数据
一个int所能表示范围就是 -2^31 -> 2^31-1
在java内,我们可以看到每个基本类型的范围:
System.out.println(Integer.MAX_VALUE);//最大值 System.out.println(Integer.MIN_VALUE);//最小值
但是仅有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);
这个值我觉得可以满足我们的使用了,但是小数问题呢?
三、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);
为什么在末尾会有个神奇的 '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);
2. 因为能表示中文,所以char类型占了2个字节 (这也是最大的区别,要注意)
也就意味着 char 的范围也扩大了。
六、byte与short
这两个都是表示整数,仅是范围不同而已。
byte 只占一个字节,所以范围仅有 -127 ~ 128
short 占两个字节,所以范围扩大为 -32768 -> 32767
虽然他们很小,但是省内存。看需求使用,选自己合适的最好。
未完待续。。。
到此这篇关于Java数据类型的全面剖析的文章就介绍到这了,更多相关Java 数据类型内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!