java编程思想-注解

今天开始本人对java编程思想的总结,每章的总结都希望能够通过博客的形式记录下来。那么先从个人觉得比较简单的注解开始吧

注解(元数据)提供了一种形式化的方法,使我们可以在稍后某个时刻非常方便地使用这些数据。这是书本上的定义,楼主在实际项目中,通常用于aop日志和类加载的对象注入。

jdk5有三个内置标准注解

@Override,表示当前的方法定义将覆盖超类中的方法。

@Deprecated,如果使用了该注解,在编译的时候会发出警告

@SuppressWarings,关闭不当的编译器警告信息

这是定义一个注解的列子:

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @Interface Test{}

四种元注解

 

@Target,  @Retention,  @Documented,  @Inherited

 


@Target:

   表示该注解可以用于什么地方。所修饰的对象范围:Annotation可被用于 packages、types(类、接口、枚举、Annotation类型)、类型成员(方法、构造方法、成员变量、枚举值)、方法参数和本地变量(如循环变量、catch参数)。在Annotation类型的声明中使用了target可更加明晰其修饰的目标。

  ElementType参数:

    1.CONSTRUCTOR:用于描述构造器
    2.FIELD:用于描述域
    3.LOCAL_VARIABLE:用于描述局部变量
    4.METHOD:用于描述方法
    5.PACKAGE:用于描述包
    6.PARAMETER:用于描述参数
    7.TYPE:用于描述类、接口(包括注解类型) 或enum声明


@Retention:

  表示需要在什么级别保存该注解信息。被保留的时间长短:某些Annotation仅出现在源代码中,而被编译器丢弃;而另一些却被编译在class文件中;编译在class文件中的Annotation可能会被虚拟机忽略,而另一些在class被装载时将被读取(请注意并不影响class的执行,因为Annotation与class在使用上是被分离的)。使用这个meta-Annotation可以对 Annotation的“生命周期”限制。

 

  取值(RetentionPoicy)有:

    1.SOURCE:在源文件中有效(即源文件保留)
    2.CLASS:在class文件中有效(即class保留)
    3.RUNTIME:在运行时有效(即运行时保留)


@Documented:

  将次注解包含在Javadoc中。可以被例如javadoc此类的工具文档化。Documented是一个标记注解,没有成员。


@Inherited:

  允许子类继承父类中的注解,@Inherited阐述了某个被标注的类型是被继承的。如果一个使用了@Inherited修饰的annotation类型被用于一个class,则这个annotation将被用于该class的子类。

  注意:@Inherited annotation类型是被标注过的class的子类所继承。类并不从它所实现的接口继承annotation,方法并不从它所重载的方法继承annotation。

  当@Inherited annotation类型标注的annotation的Retention是RetentionPolicy.RUNTIME,则反射API增强了这种继承性。如果我们使用java.lang.reflect去查询一个@Inherited annotation类型的annotation时,反射代码检查将展开工作:检查class和其父类,直到发现指定的annotation类型被发现,或者到达类继承结构的顶层。


默认值限制

 

元素不能有不确定的值,也就是说,元素要么具有默认值,要么在使用朱解释提供元素的值。。为了绕开约束,可以定义空字符串或者负数,以表示某个元素不存在

你可能感兴趣的:(java编程思想)