只能用于修饰方法
表示该方法是同名方法的重写的注解
可以用于修饰方法、属性、类
表示不鼓励程序员使用这样的元素
可以用于多种元素
用于抑制编译时候的警告信息,需要设定一个参数才能正常使用
如:@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(); } }
用于注解其他注解的注解
用于描述注解的适用范围
表示需要在什么级别保存该注解的信息,用于描述注解的生命周期
(SOURCE<CLASS<**RUNTIME **)PS:主要用于RUNTIME
说明该注解包含在javadoc中
说明子类可以继承父类中的该注释
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(); }