Java Grammer:数据类型
Java的数据类型我们知道,Java是一种强类型语言,类型对于Java语言来说非常的重要不言而喻,在Java中,分为基础数据类型和引用数据类型,其中基础数据类型分为了四类八种: 下面,我们来分别说一下这四类八种 整形首先,需要说明一点,在Java的整形中不存在
可以看出,取值范围取决于该类型的位数,由于Java的代码是运行在JVM中,所以该类型是独立于机器之外存在的,与机器的关系并没有很大,大大的提高了代码的可移植性。 在书写代码的时候,我们需要注意,在我们定义一个 整形默认类型我们的整数默认类型是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 这是一道很常见的面试题,其中错误的原因有两点:
这里很好的体现了整数类型的默认计算类型就是int类型~ 浮点类型浮点型有两种,一种是32位的
因为 关于float和long从上面我们可以知道float是32位的,而long是64位的,下意识的我们会认为64位的取值范围必定要大于32位的,但事实并非如此: float占了4个字节,也就是32位,其中第一位是符号位,23位是尾数位,剩下的8位都是指数位,(2^{8})为256,由于(signed)符号数的原因,也就是说,float的取值范围大致位于(2^{-126})到({2^{127}}),是要远远的大于long的取值范围的。 其实,这也诠释了另外一个浮点数问题,因为计算机是二进制的,所以无法精确的表示出浮点数,但是Java也给我们了一种解决方案,那就是我们在涉及到浮点数比较敏感的地方(比如经纬度,金钱)的时候,一定要注意使用
字符型
/** The value is used for character storage. */ private final char value[];
这里需要注意一些特殊的转义字符:
布尔型
强制类型转换byte a = 127; //right byte b = 1; //right byte c = a + b; // wrong byte d = (byte)(a + b) // right System.out.println(d); 还是这个熟悉的例子,刚刚我们已经分析了第三种情况为什么会报错,这里我们可以通过强制类型转换来强制完成这个操作。
果不其然,我们将第三句注释掉之后,代码可以正常编译通过,然后我们去运行的时候,发现打印的d的值如下: -128 这里就说到了强制类型转换会发生的一种情况,如果被转换的数值超出目标类型的取值范围,就会发生数据的丢失。 二进制在计算的时候,发生了超出数据范围的进位操作,随着强制类型转换,进位的部分被咔嚓掉,然后就发生这种情况了(熟悉原反补的同学应该明白这一点)。 varJDK 10中推出了一种新的类型 var list = new ArrayList<String>(); var x = 3; 乍一看,还真的和 var a = 3; a = [1,2,3]; 这样的写法在 本篇重点总结
公众号
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |