[Android] Java的注解笔记

2021-06-07 10:20:58 浏览数 (1)

代码语言:javascript复制
【回答】
注解相当于一张标签,我们可以给一个类、方法、方法参数等贴一张标签,这些标签可以被编译器、开发工具预先处理,从而实现特定功能,也可以在程序运行过程中用代码读取出来。

【注解】
@Override - 检查该方法是否是重写方法。如果发现其父类,或者是引用的接口中并没有该方法时,会报编译错误。
@Deprecated - 标记过时方法。如果使用该方法,会报编译警告。
@SuppressWarnings - 指示编译器去忽略注解中声明的警告。

// 从 Java 7 开始,额外添加了 2 个注解:
@SafeVarargs - Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
@FunctionalInterface - Java 8 开始支持,标识一个匿名函数或函数式接口。

【元注解】
@Retention - 标识这个注解怎么保存,是只在代码中,还是编入class文件中,或者是在运行时可以通过反射访问。
@Documented - 标记这些注解是否包含在用户文档中。
@Target - 标记这个注解应该是哪种 Java 成员。
@Inherited - 标记这个注解可以被子类继承

// 从 Java 8 开始,额外添加了 1 个注解:
@Repeatable - Java 8 开始支持,标识某注解可以在同一个声明上使用多次。

【笔记】
当开发者使用了 Annotation 修饰了类、方法、成员之后,这些 Annotation 不会自己生效,必须由开发者提供相应的代码来提取并处理 Annotation 信息,这些提取和处理 Annotation 的代码统称为 APT(Annotation Processing Tool)。

【@Inherited】

【@FunctionalInterface】
我们常用的一些接口 Callable、Runnable、Comparator 等在 JDK8 中都添加了 @FunctionalInterface 注解,@FunctionalInterface 标记在接口上,“函数式接口”是指仅仅只包含一个抽象方法的接口。

1、该注解只能标记在"有且仅有一个抽象方法"的接口上。
2、JDK8接口中的静态方法和默认方法,都不算是抽象方法。
3、接口默认继承java.lang.Object,所以如果接口显示声明覆盖了Object中方法,那么也不算抽象方法。
4、该注解不是必须的,如果一个接口符合"函数式接口"定义,那么加不加该注解都没有影响。加上该注解能够更好地让编译器进行检查。如果编写的不是函数式接口,但是加上了@FunctionInterface,那么编译器会报错。

0 人点赞