【Java基础】注解

一、内置注解

@Override : 重写 *
定义在java.lang.Override

@Deprecated:废弃 *
定义在java.lang.Deprecated

@SafeVarargs
Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。

@FunctionalInterface: 函数式接口 *
Java 8 开始支持,标识一个匿名函数或函数式接口。

@Repeatable:标识某注解可以在同一个声明上使用多次
Java 8 开始支持,标识某注解可以在同一个声明上使用多次。

@SuppressWarnings:抑制编译时的警告信息。 *
定义在java.lang.SuppressWarnings
	三种使用方式:
	1. @SuppressWarnings("unchecked") [抑制单类型的警告]
	2. @SuppressWarnings("unchecked","rawtypes") [抑制多类型的警告]
	3. @SuppressWarnings("all") [抑制所有类型的警告]

二、元注解

​ 元注解的作用是负责注解其他注解,java中定义了四个标准的meta-annotation类型,他们被用来提供对其他annotation类型作说明。

  • @Target:用来描述注解的使用范围(注解可以用在什么地方)
    • 使用范围的取值可以在枚举类ElementType中找到。
  • @Retention:表示需要在什么级别保存该注释信息,描述注解的生命周期。一般都是Runtime
    • 声明周期的取值在枚举类RetentionPolicy中定义。
    • 三个注解的声明周期长度:
      Source(源码级别) < Class(类级别) < Runtime(运行时环境)
  • @Document:说明该注解将被包含在javadoc中。
  • @Inherited:说明子类可以继承父类中的该注解。

三、自定义注解

public class MetaAnnotation {
    //使用对方法的注解
    @MyAnnotation(name = "a", age = 2, id = 34)
    public void test() {}
}
//元注解
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.CLASS)
@Inherited
@interface MyAnnotation{
    //在自定义注解中定义的方法,实际上是在使用注解的时候输入的参数名称,默认的参数名是value
    String name();
    int age();
    int id();
    //或者使用default在定义时设定默认值,在使用注解时就无需赋值了
    String[] likes() default {"dffw", "fwfew"};
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值