一、枚举类型
示例代码:
public class EnumTest {
public static void main(String[] args){
Size s=Size.SMALL;
Size t=Size.LARGE; //s和t引用的不是同一个对象
System.out.println(s==t); //运行结果为false,只有int、float数据类型为原始数据类型
System.out.println(s.getClass().isPrimitive());
Size u=Size.valueOf("SMALL"); //从字符串中转换
System.out.println(s==u); //true 输出为BOOL类型
foe(Size value:Size.values()) //列出它的所有值
{
System.out.println(value);
}
}
}
enum Size{SMALL,MEDIUM,LARGE};
该程序的运行结果是,枚举可用于switch语句中,枚举也可以像一般的类一样添加方法和属性,用于定义变量,以限制变量的赋值,赋值时通过“枚举名。值”来取得相关枚举中的值,可以使用“==”和equals()方法直接比对枚举变量的值。
二、反码、补码和原码的相关概念
1)反码:
反码的表示分为两种情况:
如果一个数为正数,则反码和原码相同. 同时 补码也和他们相同.
如果一个数为负数,则符号位不变,其余各位按原码取反。
例如: 1的原码为0000 0001,反码为0000 0001.
-1的原码为1000 0001,反码为1111 1110.
同样的问题存在于反码:+0的反码为0000 0000 -0的反码为1111 1111
2)补码:如果一个数为正,那么补码、反码原码都相同,如果一个数为负,那么他的补码就是他的反码加1。
例如:[+1] = [00000001]原 = [00000001]反 = [00000001]补
3)原码:把最高位作为符号位,0表示正数,1表示负数。其余各位代表数值本身的绝对值,例如:
1表示为0000 0001,-1表示为1000 0001
7 表示 0000 0111 -7 原码表示为: 1000 0111
在JAVA的程序中是使用补码来表示数字的。
三、Java中每个数据类型所占的位数,和表示数值的范围
1.Int 32位 取值范围为 -2的31次方到2的31次方减1之间的任意整数(-2147483648~2147483647)
2.Short 16位 取值范围为 -32768~32767之间的任意整数
3.long 64位 取值范围为 -2的63次方到2的63次方减1之间的任意整数 (-9223372036854774808~9223372036854774807)
4.float 32位 取值范围为 3.402823e+38 ~ 1.401298e-45
5.double 64位 取值范围为 1.797693e+308~ 4.9000000e-324
6.char 8位 取值范围为 -128~127
7.byte 8位 取值范围为 -128~127之间的任意整数
所得出的结论:不同的数据类型进行转换时可能会有精度的损失。
四、为什么double类型的数值进行运算得不到“数学上精确”的结果?
首先得从计算机本身讨论这个问题。计算机并不能识别除了二进制数据以外的任何数据。无论我们使用何种编程语言,在何种编程环境下工作,都要先把源程序翻译成二进制的机器码后才能被计算机识别。事实上,浮点数并不适合用于精确计算,而适合进行科学计算。Float和double型用来表示带有小数点的数,这些数都以科学计数法的形式存储。当一个数如50.534,转换成科学计数法的形式为5.053e1,它的小数点移动到了一个新的位置(即浮动)可见,浮点数本来就是用于科学计算的,用来进行精确计算实在是太不合适了。
五、以下代码的输出结果是什么?
int X=100;
int Y=200;
System.out.println("X+Y="+X+Y);
System.out.println(X+Y+"=X+Y");
运行结果的图为:
结论:在System.out.println()中,如果string字符串后面是+和变量,会自动把变量转换成string类型,则加号起连接作用,然后把两个字符串连接成一个新的字符串输出;如果先有变量的加减运算再有字符串,那么会从左到右先计算变量的加减,然后再与后面的string结合成一个新的字符串。