枚举类
1 枚举类的说明
类的对象只有有限个,确定的。当需要定义一组常量时,强烈建议使用枚举类。如果枚举类中只有一个对象,则可以作为单例模式的实现方式。
2 自定义枚举类
步骤1:提供私有化属性,private final String seasonName;步骤2:私有化构造器,private Season(String seasonName){ this.seasonName = seasonName}步骤3:构造器私有,那就内部提供实例化对象public(还得随类一起加载static),public static final Season SPRING = new Season(“春天”);步骤4:可以提供一些其他的诉求,比如get方法,重写toString。步骤5:在其他类使用的时候,就可以类名打点的方式调用。Season.SPRING
public class SeasonTest{
public static void main(String
[] args
){
Season
.WINTER
.sout
;
}
}
class Season{
private final String seasonName
;
private final String seasonDesc
;
private Season(String seasonName
){
this.seasonName
= seasonNaem
;
}
public static final Season SPRING
= new Season("春天", "春暖花开");
public static final Season SUMMER
= new Season("夏天", "夏日炎炎");
public static final Season AUTUMN
= new Season("秋天", "秋高气爽");
public static final Sesaon WINTER
= new Season("冬天", "冰天雪地");
public String
getSeasonName() {
return seasonName
;
}
public String
getSeasonDesc() {
return seasonDesc
;
}
@Override
public String
toString() {
return "Season{" +
"seasonName='" + seasonName
+ '\'' +
", seasonDesc='" + seasonDesc
+ '\'' +
'}';
}
}
3 enum定义枚举类
步骤1:提供当前枚举类的对象,多个对象之间用",“隔开,末尾对象”;"结束。步骤2:私有化属性,private final步骤3:私有化构造器,并给私有属性赋值private步骤4:其他诉求。
enum Season
{
SPRING("春天", "春暖花开"),
SUMMER("夏天", "夏日炎炎"),
AUTUMN("秋天", "秋高气爽"),
WINTER("冬天", "冰天雪地");
private final seasonName
;
private final seasonDesc
;
private Season(String seasonName
, String seasonDesc
){
this.seasonName
= seasonName
;
this.seasonDesc
= seasonDesc
;
}
}
4 枚举类常用方法
使用enum定义枚举类后,就继承了java.lang.Enum类。
values(),返回枚举类对象所构成的数组
valueOf(String objName),返回枚举类中对象名是objName的对象
如果没有objName的枚举对象,则抛出异常IllegalArgumentException
toString(),返回枚举类对象的名称
5 让枚举类实现接口
使用enum定义枚举类之后,如何让枚举类对象实现接口?
interface Info{
void show();
}
enum Season
implements Info{
@Override
public void show(){
System
.out
.println("Season实现Info接口");
}
}
enum Season
implements Info{
SPRING("春天", "春暖花开"){
@Override
public void show() {
System
.out
.println("春天实现Info接口");
}
},
SUMMER("夏天", "夏日炎炎"){
@Override
public void show() {
System
.out
.println("夏天实现Info接口");
}
},
AUTUMN("秋天", "秋高气爽"){
@Override
public void show() {
System
.out
.println("秋天实现Info接口");
}
},
WINTER("冬天", "冰天雪地"){
@Override
public void show() {
System
.out
.println("冬天实现Info接口");
}
};
}
注解
1 注解的理解
① jdk5.0 新增的功能
② Annotation 其实就是代码里的特殊标记,这些标记可以在编译,类加载,运行时被读取,并执行相应的处理。通过使用Annoation。程序员可以在不改变逻辑的情况下,在源文件中嵌入一些补充信息。
③ 在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE/Android中注解占据了更重要的角色,例如用来配置应用程序的任何切面,代替JavaEE旧版中所遗留的繁冗。代码个XML配置等。
框架 = 注解 + 反射机制 + 设计模式
2 注解的使用示例
① 示例一:生成文档相关的注解
② 示例二:在编译时进行格式检查(JDK内置的基本注解)
@Override:限定重写父类方法,该注解只能用于方法。
@Deprecated:用于表示所修饰的元素(类、方法等)已过时的。通常是因为所修饰的结构危险或存在更好的选择。
@SuppressWarnings:抑制编译器警告。
示例:跟踪代码依赖性,实现替代配置文件功能
③ 示例三:
Before:在每一个单元测试前都执行After:在每一个单元测试后都执行BeforeClass:在类加载之前执行,被BeforeClass修饰的方法AfterClass:在类加载之后执行,被AfterClass修饰的方法
3 如何自定义注解
注解声明为:@interface内部定义成员,通常用value表示可以指定成员的默认值,使用default定义如果自定义注解没有成员,表明是一个标识作用
public @
interface MyAnnotation {
String
value() default "hello";
}
4 元注解
JDK5.0提供了4个标准的meta-annotation类型
Retention,指定Annotation的生命周期。
RetentionPolicy.SOURCE:在源文件中有效(即源文件保留),编译器直接丢掉RetentionPolicy.CLASS:在class文件中有效(即class保留),JVM不会保留注解,默认!RetentionPolicy.RUNTIME:在运行时有效(即运行时保留),JVM会保留注解,程序可以通过反射获取该注解。 Target,指定Annotation可以修饰哪些元素
TYPE:用于描述类、接口、enumFIELD:用于描述域PACKAGE:用于描述包CONSTRUCTOR:用于描述构造器METHOD:用于描述方法LOCAL_VARIABLE:用于描述局部变量PARAMETER:用于描述参数 Documented:此元注解修饰的注解类,将会被javadoc工具提取成文档。默认情况javadoc不包括注解Inherited:被他修饰的注解具有继承性。
@Inherited
@Repeatable(MyAnnotations
.class)
@Retention(RetentionPolicy
.RUNTIME
)
@Target({TYPE
, FIELD
, METHOD
, PARAMETER
, CONSTRUCTOR
, LOCAL_VARIABLE
,TYPE_PARAMETER
,TYPE_USE
})
public @
interface MyAnnotation {
String
value() default "hello";
}
5 如何获取注解信息
通过发射来进行获取、调用。 前提:要求此注解的元注解Retention中声明的生命周期状态为:RUNTIME.
6 JDK8中注解的新特性
① 可重复注解
在MyAnnotation上声明@Repeatable,成员值为MyAnnotations.classMyAnnotation的Target和Retention等元注解与MyAnnotations相同。
② 类型注解
ElementType.TYPE_PARAMETER 表示该注解能写在类型变量的声明语句中(如:泛型声明。ElementType.TYPE_USE 表示该注解能写在使用类型的任何语句中。