枚举

switch

  1. 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="业务日志" )