枚举类和注解 [TOC]
1.枚举类的使用 1.枚举类的说明:
1.枚举类的理解:类的对象只有有限个,确定的。我们称此类为枚举类
2.当需要定义一组常量时,强烈建议使用枚举类
3.如果枚举类中只一个对象,则可以作为单例模式的实现方式。
2.如何自定义枚举类?步骤: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 class Season { private final String seasonName; private final String seasonDesc; private Season (String seasonName,String seasonDesc) { this .seasonName = seasonName; this .seasonDesc = seasonDesc; } public static final Season SPRING = new Season("春天" ,"春暖花开" ); public static final Season SUMMER = new Season("夏天" ,"夏日炎炎" ); public static final Season AUTUMN = new Season("秋天" ,"秋高气爽" ); public static final Season WINTER = new Season("冬天" ,"冰天雪地" ); public String getSeasonName () { return seasonName; } public String getSeasonDesc () { return seasonDesc; } @Override public String toString () { return "Season{" + "seasonName='" + seasonName + '\'' + ", seasonDesc='" + seasonDesc + '\'' + '}' ; } }
3.jdk 5.0 新增使用enum定义枚举类。步骤: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 enum Season1 { SPRING("春天" ,"春暖花开" ), SUMMER("夏天" ,"夏日炎炎" ), AUTUMN("秋天" ,"秋高气爽" ), WINTER("冬天" ,"冰天雪地" ); private final String seasonName; private final String seasonDesc; private Season1 (String seasonName,String seasonDesc) { this .seasonName = seasonName; this .seasonDesc = seasonDesc; } public String getSeasonName () { return seasonName; } public String getSeasonDesc () { return seasonDesc; } }
4.使用enum定义枚举类之后,枚举类常用方法:(继承于java.lang.Enum类) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 Season1 summer = Season1.SUMMER; System.out.println(summer.toString()); System.out.println("****************" ); Season1[] values = Season1.values(); for (int i = 0 ;i < values.length;i++){ System.out.println(values[i]); } System.out.println("****************" ); Thread.State[] values1 = Thread.State.values(); for (int i = 0 ; i < values1.length; i++) { System.out.println(values1[i]); } Season1 winter = Season1.valueOf("WINTER" ); System.out.println(winter);
使用enum定义枚举类之后,如何让枚举类对象分别实现接口:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 interface Info { void show () ; } enum Season1 implements Info { SPRING("春天" ,"春暖花开" ){ @Override public void show () { System.out.println("春天在哪里?" ); } }, SUMMER("夏天" ,"夏日炎炎" ){ @Override public void show () { System.out.println("宁夏" ); } }, AUTUMN("秋天" ,"秋高气爽" ){ @Override public void show () { System.out.println("秋天不回来" ); } }, WINTER("冬天" ,"冰天雪地" ){ @Override public void show () { System.out.println("大约在冬季" ); } }; }
2.注解的使用 1.注解的理解 ① jdk 5.0 新增的功能 ② Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理。通过使用 Annotation,
程序员可以在不改变原逻辑的情况下, 在源文件中嵌入一些补充信息。
③ 在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE/Android
中注解占据了更重要的角色,例如用来配置应用程序的任何切面,代替JavaEE旧版中所遗留的繁冗
代码和XML配置等。
框架 = 注解 + 反射机制 + 设计模式
3.注解的使用示例
如何自定义注解:参照@SuppressWarnings定义
① 注解声明为:@interface
② 内部定义成员,通常使用value表示
③ 可以指定成员的默认值,使用default定义
④ 如果自定义注解没成员,表明是一个标识作用。
说明: 如果注解有成员,在使用注解时,需要指明成员的值。 自定义注解必须配上注解的信息处理流程(使用反射)才意义。 自定义注解通过都会指明两个元注解:Retention、Target
代码举例:
1 2 3 4 5 6 7 8 9 @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" ; }
4.元注解 :对现有的注解进行解释说明的注解。 jdk 提供的4种元注解:
Retention:指定所修饰的 Annotation 的生命周期:SOURCE\CLASS(默认行为\RUNTIME
只声明为RUNTIME生命周期的注解,才能通过反射获取。
Target:用于指定被修饰的 Annotation 能用于修饰哪些程序元素
出现的频率较低
Documented:表示所修饰的注解在被javadoc解析时,保留下来。
Inherited:被它修饰的 Annotation 将具继承性。
–>类比:元数据的概念:String name = “Tom”;
5.如何获取注解信息:通过发射来进行获取、调用。 前提:要求此注解的元注解Retention中声明的生命周期状态为:RUNTIME.
6.JDK8中注解的新特性:可重复注解、类型注解 6.1 可重复注解:
在MyAnnotation上声明@Repeatable,成员值为MyAnnotations.class
MyAnnotation的Target和Retention等元注解与MyAnnotations相同。
6.2 类型注解:
ElementType.TYPE_PARAMETER 表示该注解能写在类型变量的声明语句中(如:泛型声明。
ElementType.TYPE_USE 表示该注解能写在使用类型的任何语句中。