枚举
switch
- JDK1.6之前的switch语句只支持int,char,enum类型,使用枚举,能让我们的代码可读性更强。
Java代码
enum Signal {
GREEN, YELLOW, RED
}
public class TrafficLight {
Signal color = Signal.RED;
public void change() {
switch (color) {
case RED:
color = Signal.GREEN;
break;
case YELLOW:
color = Signal.RED;
break;
case GREEN:
color = Signal.YELLOW;
break;
}
}
}
向枚举中添加新方法
- 如果打算自定义自己的方法,那么必须在enum实例序列的最后添加一个分号。而且 Java 要求必须先定义 enum 实例。
public enum Color {
RED("红色", 1), GREEN("绿色", 2), BLANK("白色", 3), YELLO("黄色", 4);
// 成员变量
private String name;
private int index;
// 构造方法
private Color(String name, int index) {
this.name = name;
this.index = index;
}
// 普通方法
public static String getName(int index) {
for (Color c : Color.values()) {
if (c.getIndex() == index) {
return c.name;
}
}
return null;
}
// get set 方法
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getIndex() {
return index;
}
public void setIndex(int index) {
this.index = index;
}
}
== 和使用equals方法的执行结果是一样的
因为枚举的赋值根本不是 new 出来的. 都是直接使用了地址, 而枚举元素本身的构造函数又被私有化了(不允许public, 如果 public 会报错). 所以在外面根本就不允许 new 一个枚举元素出来
use
public enum Method {
SELECT("查询", 1), INSERT("新增", 2), DELETE("删除", 3), UPDATE("更新", 4), IMPORT("导入", 5), EXPORT("导出", 6);
private String desc;
private Integer code;
private Method(String desc, Integer code) {
this.desc = desc;
this.code = code;
}
public String getDesc() {
return desc;
}
public int getCode() {
return code;
}
}
@Target({ElementType.PARAMETER, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AsLogger {
/**
* 模块名称
* @return
*/
String model() default "";
/**
* 操作类型
* @see [查询,新增,修改,删除,导出,导入]
* @return
*/
Method type() default Method.SELECT;
/**
* <p>
* - 日志类型
* 1. 系统日志
* 2. 业务日志
* </p>
* @return
*/
String logType() default "业务日志";
/**
* 是否写入日志
* @return
*/
boolean outDb() default true;
/**
* 具体详情
* @return
*/
String name() default "";
}
// 在 controller 方法 中 使用
@AsLogger(model="系统运行情况",type=Method.SELECT,logType="业务日志" )