Java基础之注解(Annotation)

注解(Annotation)

一、内置注解

1、@Override

只能用于修饰方法

表示该方法是同名方法的重写的注解

2、@Deprecated

可以用于修饰方法、属性、类

表示不鼓励程序员使用这样的元素

3、@Suppresswarnings

可以用于多种元素

用于抑制编译时候的警告信息,需要设定一个参数才能正常使用

如:@suppresswarnings(“all”) 可以抑制所有警告

//内置注解
public class Test01 {

    @Override
    public String toString() {
        return super.toString();
    }

    @Deprecated
    public static void test()
    {
        System.out.println(new String("desperated"));
    }

    @SuppressWarnings("all")
    public static void warn()
    {
        System.out.println(new String("do not warn"));
    }

    public static void main(String[] args) {
        test();
        warn();
        new Test01().toString();
    }
}

二、元注解

用于注解其他注解的注解

1、@Target

用于描述注解的适用范围

2、@Retention

表示需要在什么级别保存该注解的信息,用于描述注解的生命周期

(SOURCE<CLASS<**RUNTIME **)PS:主要用于RUNTIME

3、@Documented

说明该注解包含在javadoc中

4、@Inherited

说明子类可以继承父类中的该注释

三、自定义注解

@interface

1、用于自定义注解,格式为 : (public) +@interface+注解名+{定义内容}

2、参数为基本类型

3、注解的参数的格式为: 参数类型+参数名+();

4、可以使用default给注解的参数赋默认值

5、当只有一个参数且参数名为value的时候,赋值时可以省略value

//元注解和自定义注解
import java.lang.annotation.*;

public class Test02 {

    @Myannotation(value = "xiafan")
    public void test()
    {
        System.out.println("hello,java");
    }

}

//自定义注解

//元注解参数中的value可以删除,比如 value = ElementType.METHOD 相当于 ElementType.METHOD

//target表示可以用在什么地方
@Target(value = ElementType.METHOD)
//retention表示注解的生命周期(在什么地方有效)
@Retention(value = RetentionPolicy.RUNTIME)
//documented表示是否将注解生成在javadoc中
@Documented
//子类可以继承父类的注解
@Inherited

@interface Myannotation{

    int age () default 15; //default设置默认值
    String value();
}
上一篇:MySQL索引


下一篇:springboot2.4跨域配置的方法