@Override
-在java.lang.Override中,此注解只是用于修饰方法,表示一个方法声明打算重写超类中的一个方法声明。
@Deprecated
-定义在java.lang.Deprecated中,此注释可用于修饰方法,属性,类,不鼓励程序员使用这样的元素,通常是因为他很危险或者存在更好的选择。
@ SuppressWarring
-定义在java.lang.SuppressWarnings中,用来抑制编译时的警告信息。
@SupressWarnings
-定义在java.lang.SupressWarnings中,用来抑制编译时的警告信息。
-与前两个注释有所不同,你需要添加一个参数才能正确使用,这些参数的值已经定义好了。如下:
元注解的作用就是负责注解其他注解。java定义了4个标准的meta-annotation类型,他们用来提供对其他annotation类型说明。
这些类型和他们所支持的类在java.lang.annotation包中可以找到
-@Target
-@Retention
-@Documentd
-@Inherited
自定义注解常用于反射中,
需求在数据库中字段的名称和类中字段名称相对应。
Table.java
@Target(value = {ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface Table {
String value();
}
FieldA.java
@Target(value = {ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface FieldA {
String columnName();
String type();
int length();
}
Student.java
@Table("tb_student")
public class Student {
@FieldA(columnName = "db_id",type = "int",length = 10)
private int id;
@FieldA(columnName = "db_age",type = "int",length = 3)
private int age;
@FieldA(columnName = "db_name",type = "String",length = 10)
private String name;
public int getId(){
return id;
}
private void setId(int id){
this.id=id;
}
public String getName(){
return name;
}
public void setName(String name){
this.name=name;
}
public int getAge(){
return age;
}
public void setAge(int age){
this.age=age;
}
}
Demo
public class Demo {
/**
* 使用反射读取注解的信息,模拟处理注解信息的流程
*/
public static void main(String[] args) throws ClassNotFoundException, NoSuchFieldException {
Class clazz=Class.forName("Student");
//获取该类的所有注解
Annotation[] declaredAnnotations = clazz.getDeclaredAnnotations();
for(Annotation a:declaredAnnotations){
System.out.println(a);
}
//获得类的所有有效注解
Annotation[] annotations = clazz.getAnnotations();
//通过注解的名字获取注解
Table tab = (Table)clazz.getAnnotation(Table.class);
//获得类的属性的注解
Field name = clazz.getDeclaredField("name");
FieldA ff= name.getAnnotation(FieldA.class);
System.out.println(ff.columnName()+ff.type()+ff.length());
}
}