Java自定义注解及注解的使用

来源:互联网 发布:软件程序 编辑:程序博客网 时间:2024/09/21 08:59

Annotation,是Java5的新特性……

1、自定义注解

如何自定义一个注解,看下面的代码,其实代码没几句,都是注释,写的很详细,看完就会自定义注解了

package com.sl.annotation;import java.lang.annotation.Documented;import java.lang.annotation.ElementType;import java.lang.annotation.Inherited;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;/** * @Retention; * 指定被修饰的Annotation可以保留多长时间; * 只有一个参数,参数类型RetentionPolicy value(); * 可以@Retention(RetentionPolicy.XXX)或者@Retention(value=RetentionPolicy.XXX) * 两种用法;参数的值有三个: * RetentionPolicy.SOURCE Annotation只保留在源码中 * RetentionPolicy.CLASS  Annotation保留在源码和class文件中 * RetentionPolicy.RUNTIME Annotation记录在class中,当java程序运行时也会保留在JVM中 */@Retention(RetentionPolicy.RUNTIME)/** * @Target * 指定被修饰的Annotation能用于修饰哪些程序单元 * 只有一个参数,参数类型ElementType[] value(); * 只需要修饰一个target时可以@Target({ElementType.METHOD})或@Target(ElementType.METHOD) * 当修饰的target有多个时,则@Target({ElementType.METHOD,ElementType.FIELD}),target不能重复 * 参数值如下: * ElementType TYPE; 类、接口、枚举 * ElementType FIELD; 成员变量 * ElementType METHOD; 方法 * ElementType PARAMETER; 参数 * ElementType CONSTRUCTOR; 构造函数 * ElementType LOCAL_VARIABLE; 局部变量 * ElementType ANNOTATION_TYPE; 只能修饰Annotation * ElementType PACKAGE; 修饰包 */@Target({ElementType.METHOD,ElementType.FIELD})/** * 修饰后,Annotation将具有继承性,也就是对被Annotation修饰的类的子类也有效 * 但是!annotations on implemented interfaces have no effect. * 也就是这个修饰对于接口interface无效 */@Inherited/** * 修饰后Annotation能被javadoc提取为文档 */@Documented/** * 定义一个Annotation * 用@interface修饰,和定义interface很像 */public @interface Song {/** * 1、 * 定义成员变量: * 以无参的方法形式声明,其方法名和返回值定义了该成员变量的名字和类型,如: * String name();成员变量名为name,类型为String如果要设默认值的话可以加default valu * String name() default "songlin"; *//** * 2、 * 没有定义成员变量的Annotation类型成为标记,如@Override *//** * 3、 * 如果只有一个成员变量时,变量名取名value,如: * String value(); *//** * 4、多个成员变量时: */String name();int age();String desc() default "desc";/**-------------------Annotation定义完成!!!-----------------*/}
超级简单!

2、使用注解,注解的使用和public、void、static 、final的用法差不多,只不过习惯上喜欢单独放一行

package com.sl.annotation;public class Person {@Song(age = 12, name = "songlin")public int age;@Song(age = 11, name = "sl" ,desc="this is a name")public String name;public Person(){};public Person(int age, String name) {super();this.age = age;this.name = name;}public int getAge() {return age;}@Song(age = 0, name = "dfgs")public void setAge(int age) throws Exception {throw new Exception();}@Song(age = 1, name = "ddddd")public String getName() {return name;}public void setName(String name) {this.name = name;}}

定义了注解,在定义属性和方法时使用了注解,但是注解的使用还要去解析

package com.sl.annotation;import java.lang.reflect.Field;import java.lang.reflect.Method;public class ParseSongAnno {public static void parseSongAnno(Person p){Class<? extends Person> clz=p.getClass();Field[] fields = clz.getFields();for (Field field : fields) {if (field.isAnnotationPresent(Song.class)) {System.out.println("Field name="+field.getName());Song annotation = field.getAnnotation(Song.class);System.out.println("Anno:\tage:"+annotation.age()+"\tname:"+annotation.name()+"\tdesc:"+annotation.desc());}}Method[] methods = clz.getMethods();for (Method method : methods) {if (method.isAnnotationPresent(Song.class)) {System.out.println("Method name="+method.getName());Song annotation = method.getAnnotation(Song.class);System.out.println("Anno:\tage:"+annotation.age()+"\tname:"+annotation.name()+"\tdesc:"+annotation.desc());}}}}

然后在main方法中测试

package com.sl.annotation;public class AnnotationTest1 extends AnnotationTest{public static void main(String[] args){ParseSongAnno.parseSongAnno(new Person());}}

结果如下

Field name=ageAnno:age:12name:songlindesc:descField name=nameAnno:age:11name:sldesc:this is a nameMethod name=setAgeAnno:age:0name:dfgsdesc:descMethod name=getNameAnno:age:1name:ddddddesc:desc


纯粹就是自己学习的一个胡乱总结啊,勿喷,贴的都是代码,但是耽美注释很详细啊


















0 0