使用枚举,而不用int 常量的原因有哪些?
- int 常量没有type safety,表达力不强
- int 常量被编译到客户端,如果int常量发生变化,则客户端代码要重新编译
- int 常量不便于打印,debug,不能以group形式迭代,不方便获取int常量group的size
说说你对枚举的理解
- 枚举类是final类,不可继承,不可创建实例,只有声明的枚举常量
- 枚举类型是instance-controlled,它们是单例
- 枚举提供编译期类型安全
- 枚举的常量values不会被编译到客户端,所以添加或重新安排一个枚举类型的常量,不需要重新编译客户端代码
- 可以调用toString方法把枚举转换成可打印字符串
- 枚举类型可以添加任意的 methods,fields 以及实现任意的接口
如果想获取一个枚举的int值,该怎么办?
- 不要调用ordinal()方法去获取
- 通过使用私有实例域,构造函数,以及公有方法来获取
在枚举中进行逻辑操作,不要使用位域,应尽量使用EnumSet
在枚举中,不要使用ordinals来索引数组的下标,应尽量使用EnumMap
尽管你不能继承一个枚举类型,但你可以模仿它:写一个接口,然后让枚举类实现该接口
如果你写一个工具,需要程序员给源代码添加信息,请不要用字符串类型的名字模式,而应该采用注释Annotations,应该优先使用java预定义好的注释类型
在覆盖超类方法时,一定要用Override注释符
用不包含方法宣称的接口(即marker interfaces) 来定义types,比如java 中的 Serializable 接口
marker interfaces和marker annotations相比的优势有哪些?
- marker interfaces可以使用instances of
- marker interfaces 代码可以编译期进行检查
- marker interfaces 可以更精准的控制标记的粒度
- 如果你的框架中大量使用annotations,那可以考虑使用marker annotations进行标记;或者 你打算不仅仅标记程序中的类和接口,还用于标记其他元素,可以考虑使用marker annotations进行标记