标签:基本 Java 数据类型 boolean 类型 转换 byte
一、四大基本数据类型的分类
1. 整数类型:byte 、short 、int 、long
2. 浮点数类型:float 、double
3. 字符类型:char
4. 布尔类型:boolean
二、八种基本数据类型
基本数据类型 | 默认值 | 字节 | 取值范围 | 封装类 |
byte(字节型) | 0 | 1 |
-128 ~ 127 (-27~27-1) |
Byte |
short(短整型) | 0 | 2 |
-32768 ~ 32767 (-215~215-1) |
Short |
int(整型) | 0 | 4 |
-2147483648 ~ 2147483647 (-231~231-1) |
Integer |
long(长整型) | 0L 或 0l | 8 |
-9223372036854774808~9223372036854774807 (-263~263-1) |
Long |
float(单精度浮点型) | 0.0F 或 0f | 4 | 3.402823e+38~1.401298e-45 | Float |
double(双精度浮点型) | 0.0 | 8 | 1.797693e+308~4.9000000e-324 | Double |
char(字符型) | \u0000 | 2 |
Character |
|
boolean(布尔型) | false | 不确定 |
Boolean |
二、基本数据类型之间的转换
显然 boolean 与其他7种类型的数据都不能进行转换,其他的7种数据类型,它们之间都可以进行转换,转换时可能会造成精度损失。
转换分为自动转换和强制转换:
自动转换(隐式):无需任何操作。
强制转换(显式):需使用转换操作符(type)。
可以将6种数据类型按下面顺序排列:
byte < short < int < long <float < double
如果从小到大转换,那么可以直接转换。而从大到小,或者是 char 和其他6种数据类型转换,必须使用强制转换。
1. 自动转换:
自动转换时发生扩宽转换(widening conversion)。因为较大的类型(如int)要保存较小的类型(如byte),内存总是足够的,不需要强制转换。
自动转换时需要注意的几点:
(1) 在自动转换中,除了以下几种情况可能会导致精度损失以外,其他的转换都不能出现精度损失。
》int --> float
》long --> float
》long --> double
》float --> double without strictfp
除了可能的精度损失外,自动转换不会出现任何的运行时异常(Runtime Exception)。
(2) char 转换为其他6种数据类型时,会自动转换为ASCII码表中对应的数字。
(3) byte, char, short 类型的数据在参与运算时会自动转换为int类型,但当使用 ''+=" 运算符时就不会产生类型转换,
例如 short s1= 1; s1=(short) (s1+1) 。short s2 = 1;s1+=1。
2. 强制转换:
如果要把大的转成小的,或者在short与char之间进行转换,就必须强制转换,也被称作缩小转换(narrowing conversion),因为必须显式地使数值更小以适应目标类型。强制转换采用转换操作符"( )"。严格地说,将 byte 转为 char 不属于缩小转换,因为从byte到char的过程其实是byte-->int-->char,所以widening和narrowing都有。强制转换除了可能的精度损失外,还可能使模发生变化。
如果整数的值超出了byte所能表示的范围,结果将对byte类型的范围取余数。例如 a=256 超出了 byte 的范围,所以将 257 除以 byte 的范围上限(256)取余数得到 b=1;需要注意的是,当a=200时,此时除以 256 取余数应该为 -56,而不是200。
将浮点数型转换成整数类型的时候,会发生截尾(truncation),也就是把小数的部分去掉,只留下整数部分。此时如果整数超出目标类型的范围,同样会将对目标类型的范围取余数。
7种基本类型转换总结如下图:
3. 赋值及表达式中的类型转换
(1)字面值赋值:
在使用字面值对整数赋值的过程中,可以将 int 赋值给 byte short ,只要不超出范围。这个过程中的类型转换时自动完成的,但是如果你试图将 long 赋给 byte,即使没有超出范围,也必须进行强制类型转换。例如 byte b = 10L;是错的,要进行强制转换。
(2)表达式中的类型自动提升:
除了赋值以外,表达式计算过程中也可能发生一些类型转换。在表达式中,类型提升规则如下:
所有 byte/short/char 都被提升为 int。
如果有一个操作数为 long ,整个表达式提升为 long。float 和 double情况也一样。
三、其他
"=="和"equals()"方法的比较:
(1) 基本数据类型和封装类进行“==”运算符的比较,封装类将会自动拆箱后再进行比较。
(2) 两个Integer 进行“==”比较,如果其值在-128至127,那么返回true,否则返回false, 这跟Integer.valueOf()的缓冲对象有关,这里不进行赘述。
(3) 两个基本型的封装型进行equals()比较,首先equals()会比较类型,如果类型相同,则继续比较值,如果值也相同,返回 true。
(4) 封装类调用equals(),但是参数是基本类型,这时候,先会进行自动装箱,基本型转换为其封装类型,再进行(3)中的比较。
参考资料:
[1] The Java™ Tutorials ,Primitive Data Types
boolean: The boolean data type has only two possible values: true and false. Use this data type for simple flags that track true/false conditions. This data type represents one bit of information, but its "size" isn't something that's precisely defined.
Java 官方文档对 boolean 的占用字节大小并不是精确定义的。
[2] The Java Virtual Machine Specification 简书@马剑威
《Java虚拟机规范》书中的描述:“虽然定义了boolean这种数据类型,但是只对它提供了非常有限的支持。在Java虚拟机中没有任何供boolean值专用的字节码指令,Java语言表达式所操作的boolean值,在编译之后都使用Java虚拟机中的int数据类型来代替,而boolean数组将会被编码成Java虚拟机的byte数组,每个元素boolean元素占8位”。
[3] Java 基本数据类型 - 四类八种 知乎@韦庆明
[4] Java关键字-strictfp CSDN@zmken497300
[5] Java 八种基本类型和基本类型封装类 博客园@戏路很宽丶
标签:基本,Java,数据类型,boolean,类型,转换,byte 来源: https://www.cnblogs.com/manchuria-saika/p/11704053.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。