如清晰度低,可转PC网页观看高清版本:
http://v.qq.com/x/page/g05026wfgfl.html
注解是附加到代码中的一些元信息,这些元信息是在代码运行、编译时有效,且这些注解并不影响我们原有的代码逻辑,只是起到说明、配置的作用
自定义注解:
元注解:
注解中的注解
eg:
1.@Target,修饰的对象范围
2.@Retention,保留的时间长短
3.@Documented,标记注解 公共API 没有成员
4.@Inherited 标记注解 @Inherited阐述了某个被标注的类型是被继承的
注解使用范围:
@Target说明了Annotation所修饰的对象范围
1.CONSTRUCTOR:用于描述构造器
2.FIELD:用于描述域(属性)(常用)
3.LOCAL_VARIABLE:用于描述局部变量
4.METHOD:用于描述方法(常用、get方法,这个时候Spring2.3)
5.PACKAGE:用于描述包
6.PARAMETER:用于描述参数
7.TYPE:用于描述类、接口(包括注解类型) 或enum声明
@Retention定义了该Annotation被保留的时间长短
取值(RetentionPoicy)有:
1.SOURCE:在源文件中有效(即源文件保留)
2.CLASS:在class文件中有效(即class保留)
3.RUNTIME:在运行时有效(即运行时保留)
是从spring2.3、struts2之后才原生出来的,并且@Transient 是在jdk1.5之后才有的 Transient注解,项目中是重写了原有的注解
eg:
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Transient {
String value() default "";//注解的属性
}
1:@Transient,自定义注解,如果作用于域(属性)上面,则代表该属性不能被持久化序列
2:如果使用了该自定义注解,则代表该属性并非数据库表的的映射字段,ORM框架映射的时候,会自动忽略该属性
3:起到聚合VO的作用
4:Serializable提供了持久化实例的安全机制,如果使用了该注解的字段,则该字段不能被实例化或者序列化
示例:
1:自定义一个注解
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Name {
String value() default "java";
}
2:编写实体类,并注解字段
public class NameEntity {
@Name
private String usrname;
private String homeArr;
public String getUsrname() {
return usrname;
}
public void setUsrname(String usrname) {
this.usrname = usrname;
}
public String getHomeArr() {
return homeArr;
}
public void setHomeArr(String homeArr) {
this.homeArr = homeArr;
}
}
测试类:
public static void getNameInfo(Class<?> clazz){
String usrname = "";
Field[] fileds = clazz.getDeclaredFields();
for (Field filed : fileds) {
if (filed.isAnnotationPresent(Name.class)) {
Name arg1 = filed.getAnnotation(Name.class);
usrname = usrname + arg1.value();
System.out.println("username = " + usrname);
}
}
}