Java高级--注解(Annotation)

注释和注解:

注释:Java不会编译注释的内容,注释是给程序员看的;

注解:注解是给程序看的,当程序看到这个注解时,解析这个注解。

注解的分类

1、预定义注解

2、自定义注解

3、元注解

(1)预定义注解

预定义注解就是jdk自带的一些注解,该注解被jvm解析

1. @Override: 重写的注解。符合重写得规则。
2. @Deprecated: 表示已过时。
3. @SuppressWarnings: 表示压制警告。
4. @FunctionInterface: 表示函数式接口。表示该接口中有且仅有一个抽象方法。

(2)元注解

定义在注解上的注解称为元注解

1. @Target(value=可以取下面这些内容): 作用限制注解使用得位置。
    /** 表示可以作用在类,接口,枚举 */
    TYPE,

    /** 属性 */
    FIELD,

    /** 普通方法上 */
    METHOD,

    /** 方法参数 */
    PARAMETER,

    /** 构造方法上 */
    CONSTRUCTOR,

    /** 局部变量 */
    LOCAL_VARIABLE

2. @Retention:  注解什么时候生效。默认时源码 java经历了那些阶段。
      源码阶段-->字节码阶段--->运行阶段
      /**
     * 源码时生效
     */
    SOURCE,

    /**
     * 字节码时生效
     */
    CLASS,

    /**
     * 运行时生效。
     * 在JVM内存中还有该注解。
     都会被设置为运行时有效
     */
    RUNTIME
    
3. @Documented 当生成API文档时该注解还存在。

4. @Inherited 是否运行被子类继承。

(3)自定义注解--初级

public @interface 注解名{
   //注解属性
}

使用自定义注解:在类,属性,方法上加上@注解名

使用注解和不使用注解没有区别,注解本身没有意义,只有在注解被解析了才会赋予真正的意义。

之后会使用反射来对注解进行解析。

(4)自定义注解--高级

@interface 注解名{
     数据类型 属性名() default 默认值;
}

其中的数据类型必须为基本类型,字符串类型,枚举类型【常量】,注解类型,数组类型【必须是上面这些类型的数组】

//只能在类上使用
@Target(value = ElementType.TYPE)
//在运行时有效
@Retention(value = RetentionPolicy.RUNTIME)
//生成api时有注解
@Documented
public @interface Custom {
    String[] name() default "dumpling";
    String[] value();
}


@Custom(value = {"自己定义的","有我的名字"})
public class Myself {
    //报错
    //@Custom()
    public void testMethod(){}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值