首页 > 代码库 > java 类型转换

java 类型转换

一.动手动脑
(1)仔细阅读示例: EnumTest.java,运行它,查看运行结果

技术分享

(2)你能得到什么结论?你掌握了枚举类型的基本用法了吗?
·枚举类型是引用类型。枚举不属于原始数据类型,它的每个具体值都   引用一个特定的对象。相同的值则引用同一个对象。可以使用“==”   和equals()方法直接比对枚举变量的值,换句话说,对于枚举类型的   变量,“==”和equals()方法执行的结果是等价的。

 

二.数值的二进制表示
(1)反码、补码跟原码这几个概念,然后编写示例程序,对正数、负数进行各种位操作,观察输出结果,与手工计算的结果进行比对,看看Java 中的数是采用上述哪种码表示的。
1.原码:一种计算机中对数字的二进制定点表示方法。原码表示法在数值前面增加了一位符号位(即最高位为符号位):正数该位为0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。
2.反码:对于正数,它的反码表示与原码相同;对于负数,是其原码逐位取反,但符号位除外。
3.补码:对于正数,于原码相同;对于负数,则是反码加1。
4.Java用的是补码。

 

三.动手实验
请运行以下代码(TestDouble.java)你看到了什么样的输出,意外吗?

技术分享
你知道原因吗
(1)为什么double类型的数值进行运算得不到“数学上精确”的结果。
·因为java中十进制与二进制转化时存在问题,double类型的数值占   用64bit,即64个二进制数,除去最高位表示正负符号的位,在最低   位上一定会与实际数据存在误差,简单来说就是我们给出的数值,在   大多数情况下需要比64bit更多的位数才能准确表示出来(甚至是需   要无穷多位),而double类型的数值只有64bit,后面舍去的位数一定会带来误差,无法得到“数学上精确”的结果。

四.动手动脑
(1)以下代码的输出结果是什么?
  int X=100;
  int Y=200;
  System.out.println("X+Y="+X+Y);
  System.out.println(X+Y+"=X+Y");

 

技术分享


(2)为什么会有这样的输出结果?
1.第一个加号是连接符的作用。
2.第二个加号是运算的意思。
六.Java变量遵循“同名变量的屏蔽原则”
·输出结果是2。
·输出的是主函数之中的值!

java 类型转换