zoukankan      html  css  js  c++  java
  • 一、基础篇--1.1Java基础-自定义注解的场景及实现

    自定义注解使用场景:

    • 类属性自动赋值,例如对上下文、传入参数等赋值
    • 验证对象属性完整性,例如,对参数的校验
    • 代替配置文件功能,像spring基于注解的配置
    • 可以生成文档,例如java 最早提供的注解。常用的有@param @return 等
    • 利用注解针对性做一些前置或者后置的处理,例如记录日志、检验权限等

    自定义注解会需要元注解,此处先介绍元注解。

    元注解包含四种:@Retention、@Inherited、@Documented、@Target

    @Documented –注解是否将包含在JavaDoc中
    @Retention –什么时候使用该注解
    @Target –注解用于什么地方
    @Inherited – 是否允许子类继承该注解

     1.)@Retention– 定义该注解的生命周期
      ●   RetentionPolicy.SOURCE : 在编译阶段丢弃。这些注解在编译结束之后就不再有任何意义,所以它们不会写入字节码。@Override, @SuppressWarnings都属于这类注解。
      ●   RetentionPolicy.CLASS : 在类加载的时候丢弃。在字节码文件的处理中有用。注解默认使用这种方式
      ●   RetentionPolicy.RUNTIME : 始终不会丢弃,运行期也保留该注解,因此可以使用反射机制读取该注解的信息。我们自定义的注解通常使用这种方式。

     2.)Target – 表示该注解用于什么地方。默认值为任何元素,表示该注解用于什么地方。可用的ElementType参数包括

      ● ElementType.CONSTRUCTOR:用于描述构造器
      ● ElementType.FIELD:成员变量、对象、属性(包括enum实例)
      ● ElementType.LOCAL_VARIABLE:用于描述局部变量
      ● ElementType.METHOD:用于描述方法
      ● ElementType.PACKAGE:用于描述包
      ● ElementType.PARAMETER:用于描述参数
      ● ElementType.TYPE:用于描述类、接口(包括注解类型) 或enum声明

     3.)@Documented–一个简单的Annotations标记注解,表示是否将注解信息添加在java文档中。

     4.)@Inherited – 定义该注释和子类的关系
         @Inherited 元注解是一个标记注解,@Inherited阐述了某个被标注的类型是被继承的。如果一个使用了@Inherited修饰的annotation类型被用于一个class,则这个annotation将被用于该class的子类。

    自定义注解的定义:

    • Annotation型定义为@interface, 所有的Annotation会自动继承java.lang.Annotation这一接口,并且不能再去继承别的类或是接口.
    • 参数成员只能用public或默认(default)这两个访问权修饰 
    • 参数成员只能用基本类型byte,short,char,int,long,float,double,boolean八种基本数据类型和String、Enum、Class、annotations等数据类型,以及这一些类型的数组.要获取类方法和字段的注解信息,必须通过Java的反射技术来获取 Annotation对象,因为你除此之外没有别的获取注解对象的方法
    • 注解也可以没有定义成员, 不过这样注解就没啥用了
    • 自定义注解需要使用到元注解

     https://blog.csdn.net/PORSCHE_GT3RS/article/details/80304701 

  • 相关阅读:
    【待补充】Spark 集群模式 && Spark Job 部署模式
    Spark 集群管理命令
    Spark job 部署模式
    [Spark Core] Spark 核心组件
    [Spark RDD_1] RDD 基本概念
    【读书笔记】《天才在左 疯子在右》
    [Spark Core] Spark 使用第三方 Jar 包的方式
    [Spark Core] 在 Spark 集群上运行程序
    【待补充】[Spark Core] Spark 实现标签生成
    Spark 集群搭建
  • 原文地址:https://www.cnblogs.com/foreverYoungCoder/p/10174292.html
Copyright © 2011-2022 走看看