1.仔细阅读示例: EnumTest.java,运行它,分析运行结果?
你能得到什么结论?你掌握了枚举类型的基本用法了吗?
枚举是类型安全的常量集合,比 static final int 更安全。
可以使用 switch 语句处理枚举值。
每个枚举值都有一个 ordinal() 方法,返回它在枚举中定义的顺序(从 0 开始)。
values() 方法可以返回所有枚举值,用于遍历。
枚举可以像类一样定义字段、构造方法、方法。
2.以下代码的输出结果是什么?
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("X+Y="+X+Y);
这里 字符串拼接 是从左到右进行的。
"X+Y=" 是一个字符串,所以后面的 + 会被当作字符串连接符,而不是数学加法。
因此:
先变成 "X+Y=" + X → "X+Y=100"
再变成 "X+Y=100" + Y → "X+Y=100200"
System.out.println(X+Y+"=X+Y");
这里 X+Y 在前,先进行整数加法,因为前面没有字符串。
所以:
X + Y → 100 + 200 = 300
然后 300 + "=X+Y" → 字符串拼接 → "300=X+Y"
3.请运行以下代码(TestDouble.java)
public class TestDouble {
public static void main(String args[]) {
System.out.println("0.05 + 0.01 = " + (0.05 + 0.01));
System.out.println("1.0 - 0.42 = " + (1.0 - 0.42));
System.out.println("4.015 * 100 = " + (4.015 * 100));
System.out.println("123.3 / 100 = " + (123.3 / 100));
}
}
输出结果
0.05 + 0.01 = 0.060000000000000005
1.0 - 0.42 = 0.5800000000000001
4.015 * 100 = 401.49999999999994
123.3 / 100 = 1.2329999999999999
这是因为 Java 中的 double 和 float 是浮点数,它们使用 IEEE 754 标准 表示,不能精确表示所有小数。就像十进制中无法精确表示 1/3 一样,二进制也无法精确表示 0.1、0.01 等。