1.运行EnumTest.java,并分析结果,得出结论。
其源代码以及运行结果截图如下:
枚举类型的常量以字符串的形式顺序储。源代码中s和t不是原始数据类型。getCLass():取得当前对象所属的Class对象 ;isPrimitive:用来判断指定的Class类是否为一个基本类型;s.getClass().isPrimitive()用来判断s是否是基本类型。Size u=Size.valueOf("SMALL");用来转化数据类型。Size.value()可遍历Size中的所有元素。使用“==”和equals()方法直接比对枚举变量的值。
2.阅读相应教材,或者使用互联网搜索引擎,弄清楚反码、补码跟源码这几个概念,然后编写实例程序,对正数、负数进行各种位操作,观察输出结果,与手工计算结果进行对比,看看Java中的数是采用上述哪种码表示的。
原码:原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值。
反码:正数:正数的反码与原码相同。负数:负数的反码,符号位为“1”,数值部分按位取反。可见如果一个反码表示的是负数, 人脑无法直观的看出来它的数值. 通常要将其转换成原码再计算。
补码:正数的补码就是其本身。负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1. (即在反码的基础上+1)。对于负数, 补码表示方式也是人脑无法直观看出其数值的. 通常也需要转换成原码在计算其数值。
3.Java变量遵循“同名变量的屏蔽原则”,请课后阅读相关资料弄清楚相关知识,然后自己编写一些测试代码,就象本示例一样,有意识地在不同地方定义一些同名变量,看看输出的到底是哪个值。
每个变量都有一个“有效”的区域,成为有效域,出了这个区域,变量将不再有效。
4.查看Java中每个数据类型所占的位数,和表示数值的范围,你能得出什么结论?
基本数据类型有:
int长度数据类型有:byte(8bits)、short(16bits)、int(32bits)、long(64bits);
float长度数据类型有:单精度(32bits)、双精度(64bits double);
Boolen类型变量的取值有:ture、false;
Char数据类型有:unicode字符;
16位对应的类类型有:Integer 、Float、Boolean、Character、Double、Short、Byte、Long
结论:从低精度向高精度转换、基本类型向类类型转换、类类型向字符串转换、基本类型向字符串的转换
5.为什么double类型的数值进行运算得不到“数学上精确”的结果?
float 和double类型主要是为科学计算和工程计算而设计的,他们执行二进制浮点运算,这两种类型在计算机中的储存分为三部分:符号位、指数为、尾数部分。数据以二进制存储在计算机时,会出现无线循环系列,在数据转化中会出现错误。十进制不能准确的表示1/3,同样二进制不能精确的表示1/10。
在构建BigDecimal对象时应使用字符串而不是double数值,否则,仍有可能引发计算精度问题。(为什么会这样呢?)
double+、-不能准确的代表BigDecimal(String) 16位有效数以上的数字在使用BigDecimal时,应用*、/构造器创建对象才有意义。BigDecimal所创建的对象不能使用传统的等算术运算符直接对其对象进行数学运算,而必须调用相对应的方法。方法中的参数必须是BigDecimal的对象。
6.
以下代码的输出结果是什么?
int X=100;
int Y=200;
System.out.println("X+Y="+X+Y);
System.out.println(X+Y+"=X+Y");
为什么会有这样的输出结果?
输出结果如下:
X+Y=100200
300=X+Y
原因:System.out.println(str)其本身输出的就是字符串,而根据运算符的优先级规则,System.out.println("X+Y="+X+Y);语句则是输出字符串X(100)之后再次输出字符串Y(200),故该语句的输出结果为X+Y=100200;而System.out.println(X+Y+"=X+Y");语句则是先将字符串X和Y转化为ASCALL码,然后相加输出相加之后的结果300,故输出结果为300=X+Y。