[改善Java代码]在switch的default代码块中增加AssertionError错误

switch的后跟枚举类型,case后列出所有的枚举项,这是一个使用枚举的主流写法,那留着default语句似乎没有任何作用了,程序已经列举出了所有的可能选项,肯定不会执行到default语句,.

错了...这个default还是很有用的,以我们定义的日志级别来举例说明,这是一个典型的枚举常量.如下所示:

 public class Client {
public static void main(String[] args) {
LogLevel logLevel = LogLevel.INFO;
switch (logLevel) {
case DEBUG:
System.out.println("****Debug Log*****");
break;
case INFO:
System.out.println("****Info Log*****");
break;
case WARN:
System.out.println("****Warn Log*****");
break;
case ERROR:
System.out.println("****Error Log*****");
break;
}
}
} enum LogLevel {
DEBUG, INFO, WARN, ERROR;
}

把所有的枚举项都列举完了,不可能有其他值,所以就不需要default代码块了,这是普遍认识,但问题是我们的switch代码块与枚举之前没有强制约束关系,也就说两者只是在语义上建立了联系,并没有一个强制约束,比如LogLevel枚举发生改变,增加了一个枚举项FATAL,如果此时我们对switch不做任何的修改,编译虽然不会出现问题,但是运行期会发生非预期的错误:FATAL类型的日志没有输出.

为了避免这类的非预期的错误,建议在default后直接抛出一个AssertionError错误,其含义就是"不要跑到这里来,一跑到这里就会出问题",这样一来很容易查找到错误,方便立刻排除.

当然也有其他方法可以解决此问题,比如修改IDE工具,以Eclipse为例,可以把Java--->Complier---->Errors/Warnings中的"Enum type constant not covered on switch"设置为Error级别,如果不判断所有的枚举项就不能通过编译.

上一篇:Linux的定时服务相关(查看 启动 停止)


下一篇:Prefix tree