咱们知道,Java是一种强类型语言,类型对于Java语言来讲很是的重要不言而喻,在Java中,分为基础数据类型和引用数据类型,其中基础数据类型分为了四类八种:javascript
下面,咱们来分别说一下这四类八种java
首先,须要说明一点,在Java的整形中不存在unsigned
类型的数值,也就是说Java的整形都是有符号的可为正,可为负的整数面试
名称 | 取值范围 | 字节数 | 位数 | 包装类 |
---|---|---|---|---|
byte | ![]() ![]() |
1 | 8 | Byte |
short | ![]() ![]() |
2 | 16 | Short |
int | ![]() ![]() |
4 | 32 | Integer |
long | ![]() ![]() |
8 | 64 | Long |
能够看出,取值范围取决于该类型的位数,因为Java的代码是运行在JVM中,因此该类型是独立于机器以外存在的,与机器的关系并无很大,大大的提升了代码的可移植性。数组
在书写代码的时候,咱们须要注意,在咱们定义一个long
类型的变量时,必定要记得在代码后加上大写的L(小写的l在某些字体下容易被认证1,给代码的可读性带来影响)。bash
咱们的整数默认类型是int类型,在咱们进行计算的时候,会默认按照int类型进行计算。数据结构
byte a = 127; //right
byte b = 1; //right
byte c = a + b; // wrong
byte d = 127 + 1; //wrong
复制代码
编译器报错两处,均是下面的这个错误信息:字体
HelloWorld.java:7: 错误: 不兼容的类型: 从int转换到byte可能会有损失
byte c = a + b; // wrong
^
HelloWorld.java:9: 错误: 不兼容的类型: 从int转换到byte可能会有损失
byte d = 127 + 1; //wrong
复制代码
这是一道很常见的面试题,其中错误的缘由有两点:spa
这里很好的体现了整数类型的默认计算类型就是int类型~code
浮点型有两种,一种是32位的float
类型(单精度),一种是64位的double
类型(双精度)。cdn
名称 | 取值范围 | 字节数 | 位数 | 包装类 |
---|---|---|---|---|
float | 大约![]() ![]() |
8 | 32 | Float |
double | 大约![]() ![]() |
16 | 64 | Double |
由于double
的取值范围更广,精度更高,因此咱们平常都是使用double
,默认的浮点类型也是double
。
从上面咱们能够知道float是32位的,而long是64位的,下意识的咱们会认为64位的取值范围一定要大于32位的,但事实并不是如此:
float占了4个字节,也就是32位,其中第一位是符号位,23位是尾数位,剩下的8位都是指数位,为256,因为(signed)符号数的缘由,也就是说,float的取值范围大体位于
到
,是要远远的大于long的取值范围的。
其实,这也诠释了另一个浮点数问题,由于计算机是二进制的,因此没法精确的表示出浮点数,可是Java也给咱们了一种解决方案,那就是咱们在涉及到浮点数比较敏感的地方(好比经纬度,金钱)的时候,必定要注意使用BigDecimal
传参为字符串的方式!
三个特殊的浮点数值:
- 正无穷大(Double.POSITIVE_INFINITY)
- 负无穷大(Double.NEGATIVE_INFINITY)
- NAN(Double.NaN)
char
关键字所修饰的类型是字符型,须要由单引号引发来,一个或两个char
类型的数值能够表示一个Unicode
字符,咱们所熟知的字符串底层数据结构正是一个字符数组常量:
/** The value is used for character storage. */
private final char value[];
复制代码
char
类型实际上是由\u+十六进制数据的组成的
,最大值为\uffff(65535)
,最小值为\u0000(0)
。
这里须要注意一些特殊的转义字符:
转义序列 | 名称 | Unicode值 |
---|---|---|
\b | 退格 | \u0008 |
\t | 制表 | \u0009 |
\n | 换行 | \u000a |
\r | 回车 | \u000d |
\" | 双引号 | \u0022 |
\' | 单引号 | \u0027 |
\\ | 反斜杠 | \u005c |
boolean
修饰的变量就是布尔型,布尔类型很简单,只有true false
两个值,可是这里须要注意,和C++不一样的地方是它不能由数字0或1转换成布尔型。
byte a = 127; //right
byte b = 1; //right
byte c = a + b; // wrong
byte d = (byte)(a + b) // right
System.out.println(d);
复制代码
仍是这个熟悉的例子,刚刚咱们已经分析了第三种状况为何会报错,这里咱们能够经过强制类型转换来强制完成这个操做。
强制类型转换只发生在位数较多的类型(int,64位)转为位数较少(byte,8位)的类型。
果不其然,咱们将第三句注释掉以后,代码能够正常编译经过,而后咱们去运行的时候,发现打印的d的值以下:
-128
复制代码
这里就说到了强制类型转换会发生的一种状况,若是被转换的数值超出目标类型的取值范围,就会发生数据的丢失。
二进制在计算的时候,发生了超出数据范围的进位操做,随着强制类型转换,进位的部分被咔嚓掉,而后就发生这种状况了(熟悉原反补的同窗应该明白这一点)。
JDK 10中推出了一种新的类型var
,猛地看起来很像javascript
中的var
,它能够这么玩:
var list = new ArrayList<String>();
var x = 3;
复制代码
乍一看,还真的和javascript
有些像,但其实并否则,并不会影响Java是一个强类型语言的事实,它是基于局部变量推断机制来完成的,编译器在处理var时,先读构造器,并将它做为变量的类型,而后将该类型写入字节码当中。也就是说,该类型是没法更改的。
var a = 3;
a = [1,2,3];
复制代码
这样的写法在javascript
中毫无问题,可是在Java中就不行。可是须要注意,var
只能做用于带有构造器的局部变量和for循环中。
原创文章,才疏学浅,若有不对之处,万望告知!