目录
一、枚举类的使用
1.枚举类的理解:类的对象只有有限个,确定的,我们称此类为枚举类 2.当需要定义一组常量时,强烈建议使用枚举类 3.如果枚举类中只有一个对象,则可以作为单例模式的实现方式 2)、如何定义枚举类 方式一:jdk5.0之前,自定义枚举类 方式二:jdk5.0,可以使用enum关键字定义枚举类 3)、Enum类的主要方法 values()方法:返回枚举类型的对象数组。该方法可以很方便的遍历所有枚举值。 valueOf(String str):可以把一个字符串转为对应的枚举对象。要求字符串必须是枚举对象的“名字”。如不是,会有运行时异常:IllegalArgumentException。 toString():返回当前枚举类对象常量的名称 4)、使用enum关键字定义的枚举类实现接口的情况 情况一:实现接口在enum类中实现抽象方法 情况二:让枚举类的对象分别实现接口中的抽象方法
二、注解的使用
1.理解Annotation: ①jdk5.0新增的功 ②Annotation其实就是代码里的特殊标记,这些标记可以在编译、类加载、运行时被读取,并执行相应的处理。 通过使用Annotation,程序员可以在不改变原有逻辑的情况下,在源文件中嵌入一些补充信息 ③在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE/Android中注解占据了更重要的角色, 例如用来配置应用程序的任何切面,代替JavaEE旧版本中所遗留的繁冗代码和XML配置等。 框架=注解+反射+设计模式 2.Annotation的使用实例: 常见的注解示例: 示例一:生成文档相关的注解 示例二:在编译时进行格式检查(JDK内置的三个基本注解) @Override:限定重写父类的方法,该注解只能用于方法 @Deprecated:用于表示所修饰的元素(类,方法等)已过时。通常是因为所修饰的结构危险或存在更好的选择 @SuppressWarnings:抑制编译器警告 示例三:跟踪代码依赖性,实现替代配置文件功能 自定义Annotation 如何自定义注解:参照@SuppressWarnings定义 ①注解声明为:@interface ②内部定义成员,通常使用value表示 ③可以指定成员的默认值,使用default定义 ④如果自定义注解没有成员,表明是一个标识作用 3.如何自定义注解:参照@SuppressWarnings定义 ①注解声明为:@interface ②内部定义成员,通常使用value表示 ③可以指定成员的默认值,使用default定义 ④如果自定义注解没有成员,表明是一个标识作用:比如@Override 如果注解有成员,在使用注解时,需要指明成员的值 自定义注解必须配上注解的信息处理流程(使用反射)才有意义 自定义注解通过都会指明两个元注解:Retention、Target 4.jdk提供的4种元注解 元注解:对现有的注解进行解释说明的注解 Retention:指定所修饰的Annotation的生命周期:SOURCE\CLASS(默认行为)\RUNTIME只有声明为RUNTIME生命周期的注解,才能通过反射获取。 Target:用于指定被修饰的Annotation能用于修饰哪些程序元素 出现的频率较低 Documented:表示所修饰的注解在被javadoc解析时,保留下来 Inherited:被它修饰的Annotation将具有继承性 5.利用反射获取注解信息 通过反射获取直接信息—到反射内容时系统讲解 要求此注解的元注解Retention声明的生命周期状态为RUNTIME JDK8中注解的新特性 jdk8中注解的新特性:可重复注解、类型注解 1.可重复注解: ①在MyAnnotation上声明@Repeatable,成员值为MyAnnotations.class ②MyAnnotation的Target和Retention等元注解与MyAnnotaions相同 2.类型注解: ElementType.TYPE_PARAMETER表示该注解能写在类型变量的声明语句中(如:泛型声明) ElementType.TYPE_USE表示该注解能写在使用类型的任何语句中 @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"; } class Generic<@MyAnnotation T>{ public void show() throws @MyAnnotion RuntimeException{ ArrayList<@MyAnnotation String> list = new ArrayList<>{}; int num = (@MyAnnotation int)10L; } }