主要内容
JDK内置的基本注解类型(3个)
自定义注解类型
对注解进行注解(4个)
利用反射获取注解信息(在反射部分涉及)
注解 (Annotation) 概述
从 JDK 5.0 开始, Java 增加了对元数据(MetaData) 的支持, 也就是 Annotation(注解);
Annotation 其实就是代码里的特殊标记, 这些标记可以在编译, 类加载, 运行时被读取, 并执行相应的处理. 通过使用 Annotation, 程序员可以在不改变原有逻辑的情况下, 在源文件中嵌入一些补充信息;
Annotation 可以像修饰符一样被使用, 可用于修饰包,类, 构造器, 方法, 成员变量, 参数, 局部变量的声明, 这些信息被保存在 Annotation 的 “name=value” 对中;
Annotation 能被用来为程序元素(类, 方法, 成员变量等) 设置元数据。
/*
- 注解
- 1、JDK提供的常用的注解
- @Override: 限定重写父类方法, 该注释只能用于方法
@Deprecated: 用于表示某个程序元素(类, 方法等)已过时
@SuppressWarnings: 抑制编译器警告 - 2、如何自定义注解
- 3、原注解:另外一些注解用来补充说明它自己
*/
```
package com.atguigu.java1;
import java.util.List;
import java.beans.PersistenceDelegate;
import java.util.ArrayList;
public class TestAnnotation {
public static void main(String[] args) {
Person p = new Student();
p.walk();
@SuppressWarnings({ "unused", "rawtypes" })//两个警告:"unused"是指变量没有使用;"rawtypes"没有使用泛型
List list = new ArrayList();
}
}
@MyAnnotation("atguigu")//自定义的注解,可以用来修饰属性、方法、构造器等等
class Student extends Person{
@Override//可以写也可以不写,可以避免例如方法名写错而执行了父类的方法
public void walk(){
System.out.println("学生走路");
}
@Override
public void eat(){
System.out.println("学生吃饭");
}
}
class Person{
String name;
int age;
@MyAnnotation(value = "atguigu")
public Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public Person(){
//super();
}
@Deprecated//可以用来修饰方法,也可以用来修饰类。就是告诉程序员,该方法已经过时
public void walk(){
System.out.println("走路");
}
public void eat(){
System.out.println("吃饭");
}
}
```
```
package com.atguigu.java1;
import static java.lang.annotation.ElementType.CONSTRUCTOR;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.LOCAL_VARIABLE;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.PARAMETER;
import static java.lang.annotation.ElementType.TYPE;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
/*
JDK5.0提供了专门在注解上的注解类型,称为元注解,分别是:
Retention//指明该注解的存活时间
Target//指明该注解的可修饰类型
Documented//指明该注解是否能生成java.doc文档
Inherited//说明被修饰的注解具有继承性
*/
import java.lang.annotation.Target;
//自定义的注解,使用较少
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
@Retention(RetentionPolicy.RUNTIME)//
public @interface MyAnnotation {
String value() default "hello";
}
```