Java数据类型的全面剖析

编辑: admin 分类: java 发布时间: 2021-12-03 来源:互联网
目录
  • 一、int
  • 二、long
  • 三、double
  • 四、float
  • 五、char
  • 六、byte与short

一、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 数据类型内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!

【文章出处:cc防御 转载请说明出处】