`

JAVA 注解---积累

 
阅读更多

转载http://www.iteye.com/topic/400085

 

注解(Annotation) 为我们在代码中天界信息提供了一种形式化的方法,是我们可以在稍后

某个时刻方便地使用这些数据(通过 解析注解 来使用这些数据)。

 

    注解的语法比较简单,除了@符号的使用以外,它基本上与java的固有语法一致,java内置了三种

注解,定义在java.lang包中。

      @Override  表示当前方法是覆盖父类的方法。

      @Deprecated  表示当前元素是不赞成使用的。

      @SuppressWarnings 表示关闭一些不当的编译器警告信息。

 

  下面是一个定义注解的实例

 

Java代码
  1. package Test_annotation;   
  2.   
  3. import java.lang.annotation.Documented;   
  4. import java.lang.annotation.Inherited;   
  5. import java.lang.annotation.Retention;   
  6. import java.lang.annotation.Target;   
  7. import java.lang.annotation.ElementType;   
  8. import java.lang.annotation.RetentionPolicy;   
  9.   
  10. /*  
  11.  * 元注解@Target,@Retention,@Documented,@Inherited  
  12.  *   
  13.  *     @Target 表示该注解用于什么地方,可能的 ElemenetType 参数包括:  
  14.  *         ElemenetType.CONSTRUCTOR 构造器声明  
  15.  *         ElemenetType.FIELD 域声明(包括 enum 实例)  
  16.  *         ElemenetType.LOCAL_VARIABLE 局部变量声明  
  17.  *         ElemenetType.METHOD 方法声明  
  18.  *         ElemenetType.PACKAGE 包声明  
  19.  *         ElemenetType.PARAMETER 参数声明  
  20.  *         ElemenetType.TYPE 类,接口(包括注解类型)或enum声明  
  21.  *           
  22.  *     @Retention 表示在什么级别保存该注解信息。可选的 RetentionPolicy 参数包括:  
  23.  *         RetentionPolicy.SOURCE 注解将被编译器丢弃  
  24.  *         RetentionPolicy.CLASS 注解在class文件中可用,但会被VM丢弃  
  25.  *         RetentionPolicy.RUNTIME VM将在运行期也保留注释,因此可以通过反射机制读取注解的信息。  
  26.  *           
  27.  *     @Documented 将此注解包含在 javadoc 中  
  28.  *       
  29.  *     @Inherited 允许子类继承父类中的注解  
  30.  *     
  31.  */  
  32. @Target(ElementType.METHOD)   
  33. @Retention(RetentionPolicy.RUNTIME)   
  34. @Documented  
  35. @Inherited  
  36. /*  
  37.  * 定义注解 Test  
  38.  * 注解中含有两个元素 id 和 description  
  39.  * description 元素 有默认值 "no description"  
  40.  */  
  41. public @interface Test {   
  42.     public int id();   
  43.     public String description() default "no description";   
  44. }  

   

下面是一个使用注解 和 解析注解的实例

 

Java代码
  1. package Test_annotation;   
  2.   
  3. import java.lang.reflect.Method;   
  4.   
  5. public class Test_1 {   
  6.     /*  
  7.      * 被注解的三个方法  
  8.      */  
  9.     @Test(id = 1, description = "hello method_1")   
  10.     public void method_1() {   
  11.     }   
  12.   
  13.     @Test(id = 2)   
  14.     public void method_2() {   
  15.     }   
  16.   
  17.     @Test(id = 3, description = "last method")   
  18.     public void method_3() {   
  19.     }   
  20.   
  21.     /*  
  22.      * 解析注解,将Test_1类 所有被注解方法 的信息打印出来  
  23.      */  
  24.     public static void main(String[] args) {   
  25.         Method[] methods = Test_1.class.getDeclaredMethods();   
  26.         for (Method method : methods) {   
  27.             /*  
  28.              * 判断方法中是否有指定注解类型的注解  
  29.              */  
  30.             boolean hasAnnotation = method.isAnnotationPresent(Test.class);   
  31.             if (hasAnnotation) {   
  32.                 /*  
  33.                  * 根据注解类型返回方法的指定类型注解  
  34.                  */  
  35.                 Test annotation = method.getAnnotation(Test.class);   
  36.                 System.out.println("Test( method = " + method.getName()   
  37.                         + " , id = " + annotation.id() + " , description = "  
  38.                         + annotation.description() + " )");   
  39.             }   
  40.         }   
  41.     }   
  42.   
  43. }     
输出结果如下:

    Test( method = method_1 , id = 1 , description = hello method_1 )
    Test( method = method_2 , id = 2 , description = no description )
    Test( method = method_3 , id = 3 , description = last method )
 
 
 
 第一部分:了解一下java1.5起默认的三个annotation类型:
   一个是@Override:只能用在方法之上的,用来告诉别人这一个方法是改写父类的。
   一个是@Deprecated:建议别人不要使用旧的API的时候用的,编译的时候会用产生警告信息,可以设定在程序里的所有的元素上.
   一个是@SuppressWarnings:这一个类型可以来暂时把一些警告信息消息关闭.
   如果不清楚上面三个类型的具体用法,各位可以baidu或google一下的,很简单的。

   第二部分:讲一下annotation的概念先,再来讲一下怎样设计自己的annotation.
   首先在jdk自带的java.lang.annotation包里,打开如下几个源文件:
  
   1、源文件Target.java
Java代码
  1. @Documented  
  2. @Retention(RetentionPolicy.RUNTIME)   
  3. @Target(ElementType.ANNOTATION_TYPE)   
  4. public @interface Target {   
  5.    ElementType[] value();   
  6. }  
   
   其中的@interface是一个关键字,在设计annotations的时候必须把一个类型定义为@interface,而不能用class或interface关键字(会不会觉得sun有点吝啬,偏偏搞得与interface这么像).
  
   2、源文件Retention.java
Java代码
  1. @Documented  
  2. @Retention(RetentionPolicy.RUNTIME)   
  3. @Target(ElementType.ANNOTATION_TYPE)   
  4. public @interface Retention {   
  5.    RetentionPolicy value();   
  6. }  
   看到这里,大家可能都模糊了,都不知道在说什么,别急,往下看一下.
   在上面的文件都用到了RetentionPolicy,ElementType这两个字段,你可能就会猜到这是两个java文件.的确,这两个文件的源代码如下:
  
   3、源文件RetentionPolicy.java
Java代码
  1. public enum RetentionPolicy {   
  2.  SOURCE,   
  3.  CLASS,   
  4.  RUNTIME   
  5. }  
   这是一个enum类型,共有三个值,分别是SOURCE,CLASS 和 RUNTIME.
   SOURCE代表的是这个Annotation类型的信息只会保留在程序源码里,源码如果经过了编译之后,Annotation的数据就会消失,并不会保留在编译好的.class文件里面。
   ClASS的意思是这个Annotation类型的信息保留在程序源码里,同时也会保留在编译好的.class文件里面,在执行的时候,并不会把这一些信息加载到虚拟机(JVM)中去.注意一下,当你没有设定一个Annotation类型的Retention值时,系统默认值是CLASS.
   第三个,是RUNTIME,表示在源码、编译好的.class文件中保留信息,在执行的时候会把这一些信息加载到JVM中去的.
  举一个例子,如@Override里面的Retention设为SOURCE,编译成功了就不要这一些检查的信息;相反,@Deprecated里面的Retention设为RUNTIME,表示除了在编译时会警告我们使用了哪个被Deprecated的方法,在执行的时候也可以查出该方法是否被Deprecated.


   4、源文件ElementType.java
Java代码
  1. public enum ElementType {   
  2.  TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR,   
  3.  LOCAL_VARIABLE, ANNOTATION_TYPE,PACKAGE   
  4. }  
   @Target里面的ElementType是用来指定Annotation类型可以用在哪一些元素上的.说明一下:TYPE(类型), FIELD(属性), METHOD(方法), PARAMETER(参数), CONSTRUCTOR(构造函数),LOCAL_VARIABLE(局部变量), ANNOTATION_TYPE,PACKAGE(包),其中的TYPE(类型)是指可以用在Class,Interface,Enum和Annotation类型上.
   另外,从1的源代码可以看出,@Target自己也用了自己来声明自己,只能用在ANNOTATION_TYPE之上.
   如果一个Annotation类型没有指明@Target使用在哪些元素上,那么它可以使用在任何元素之上,这里的元素指的是上面的八种类型.
   举几个正确的例子:
   @Target(ElementType.METHOD)
   @Target(value=ElementType.METHOD)
   @Target(ElementType.METHOD,ElementType.CONSTRUCTOR)  
   具体参考一下javadoc文档
  
   上面一下1和2的源文件,它们都使用了@Documented,@Documented的目的就是让这一个Annotation类型的信息能够显示在javaAPI说明文档上;没有添加的话,使用javadoc生成API文档的时候就会找不到这一个类型生成的信息.
   另外一点,如果需要把Annotation的数据继承给子类,那么就会用到@Inherited这一个Annotation类型.
  
   第三部分:下面讲的设计一个最简单的Annotation例子,这一例子共用四个文件;
   见附件:
分享到:
评论

相关推荐

    java-core-learning-example:关于Java核心技术学习积累的例子,是初学者及核心技术巩固的最佳实践

    Java核心系列教程,关于Java核心技术学习积累的例子,是初学者及核心技术巩固的最佳实践。 包括基础语法,OOP,字符串,集合,IO,反射,线程,网络等。未完成模块:阿里Java手册,java8,注解,fork / join,加解密...

    SpringMVC基础上的web框架

    这个框架是在学习Spring的时候,为了积累学习成果,自己搭建的,一般的系统开发也可以直接使用,包括一个系统开发的基础功能。 以下是当时自己开发时的日志,大致可以说明框架里已有功能 1.0.5 从web项目迁移成maven...

    数据结构算法Java实现。关于Java《数据结构算法》核心技术学习积累的例子,是初学者及核心技术巩固的最佳实践。.zip

    动态性:Java可以通过反射、注解等机制实现在运行时动态加载类和修改行为,增加了程序的灵活性。 综上所述,Java凭借其强大的特性和广泛的适用范围,在企业级应用、互联网服务、移动开发等领域均扮演着举足轻重的...

    Java 核心系列教程,关于Java核心技术学习积累的例子,是初学者及核心技术巩固的最佳实践

    Java 核心系列教程,关于Java核心技术学习积累的例子,是初学者及核心技术巩固的最佳实践。包括基础语法,OOP,字符串,集合,IO,反射,线程,网络等。 未完成模块:阿里Java手册、java8,注解,fork/join,加解密等...

    小程序 Java的UIMA注解类 uimaFIT(源码).zip

    免责声明:资料部分来源于合法的互联网渠道收集和整理,部分自己学习积累成果,供大家学习参考与交流。收取的费用仅用于收集和整理资料耗费时间的酬劳。 本人尊重原创作者或出版方,资料版权归原作者或出版方所有,...

    多年积累的基础算法等.zip

    动态性:Java可以通过反射、注解等机制实现在运行时动态加载类和修改行为,增加了程序的灵活性。 综上所述,Java凭借其强大的特性和广泛的适用范围,在企业级应用、互联网服务、移动开发等领域均扮演着举足轻重的...

    springCloud

    微服务架构引入策略 – 对传统企业而言,开始时可以考虑引入部分合适的微服务架构原则对已有系统进行改造或新建微服务应用,逐步探索及积累微服务架构经验,而非全盘实施微服务架构。 更多关于微服务架构内容-请...

    gitbooks

    作者由零基础慢慢深入,由浅入深,逐步掌握Java知识生态圈,帮助Javaava初学者和爱好者,预测帮助读者掌握Java基础知识,了解开发技巧并积累一定的项目实战经验。为什么要写这样一本书荀子曰:“不闻不若闻之,闻之...

    Basic4android库分析器兼智能提示文本汉化工具

    要想B4A最终走进中国,最关键的作法就是对B4A较熟悉人能经常到B4A中文官网给大家解答,而不懂的人常到B4A中文官网发帖子,时间一久,论坛上就积累了很多学习资料,利已利他人。而目前有很多人只考虑眼前利益,有问题...

    QsBase:Android AOP面向切面框架,使用场景:

    替代弃反射,代理等操作,稳定性和执行效率高积累很多框架封装思想,能够轻松驾驭任何典型的APP项目开发轻量级框架,轻松实现类似EventBus,ButterKnife(MVVM架构不再支持),Retrofit等核心注解功能,使代码简洁...

Global site tag (gtag.js) - Google Analytics