文章目录
- 1.什么是注解
- 2.元注解
- 1)定义
- 2)分类
- 3.内置注解
- 4.自定义注解
- 5.注解的基本语法
- 6.验证注解是否生效
- 7.注解的使用场景
- 8.注解的注意事项
- 结语
1.什么是注解
注解(Annotation)可以理解成一种特殊的 “注释”
注解定义时以 @
符号开头,可以写在包
、类
、构造方法
、方法
、字段
等元素上,为这些元素提供额外的信息。
如下图: 我们为实体类 User
添加了 两个 Lombok
的注解,用以为属性增加 set
和 get
方法
2.元注解
1)定义
元注解(meta-annotation)是用于注解其他注解的注解
这个听起来或许有一点绕,这些是注解的基础,它们用于提供注解拥有哪些行为信息。
如下图:Lombok
在定义 Getter
的时候,使用了两个元注解 @Target 和 @Retention
2)分类
-
@Target
: 用于指定注解可以应用的程序元素类型,包括TYPE
(类、接口、枚举)、FIELD
(字段)、METHOD
(方法)等。如果没有@Target
注解,注解可以应用于任何程序元素。@Target(ElementType.TYPE) public @interface DemoAnnotation {// 注解的定义 }
-
@Retention
: 用于指定注解的生命周期,即注解在何时有效。可以有三个值:SOURCE
(源代码时有效)、CLASS
(编译时有效,默认值)、RUNTIME
(运行时有效),90% 使用的都是 RUNTIME。@Retention(RetentionPolicy.RUNTIME) public @interface DemoAnnotation {// 注解的定义 }
-
@Documented
: 用于指定注解是否包含在 Javadoc 文档中。如果一个注解使用了@Documented
,那么它将会被包含在生成的文档中。@Documented public @interface DemoAnnotation {// 注解的定义 }
-
@Inherited
: 用于指定一个注解是否具有继承性。如果一个类使用了带有@Inherited
的注解,并且其子类没有使用相同的注解,那么子类将继承父类的注解。@Inherited public @interface DemoAnnotation {// 注解的定义 }
-
@Repeatable
: 用于指定注解是否可以重复应用于同一程序元素。如果一个注解使用了@Repeatable
,则可以在同一程序元素上多次使用该注解。@Repeatable(MyAnnotations.class) public @interface MyAnnotation {// 注解的定义 }public @interface MyAnnotations {MyAnnotation[] value(); }
上述元注解用于控制注解的行为,提供了更多的灵活性和可定制性。这些元注解的组合使得我们可以更加精细地定义和使用注解,以满足不同的需求。
3.内置注解
Java 提供了一些内置的注解,它们具有特殊的含义和用途。其中几个常用的内置注解包括:
@Override
: 用于标记一个方法是覆盖父类的方法。@Deprecated
: 用于标记已经过时的方法等,提醒开发者不再使用。@SuppressWarnings
: 用于抑制编译器警告。
4.自定义注解
除了使用内置注解,我们还可以定义自己的注解。自定义注解使用 @interface
关键字,并且可以定义元素(成员变量等)。
例如:
@Documented
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@interface ClassInfoAnnotation {String author();String version() default "1.0.0";String description();
}
上述代码定义了一个名为 ClassInfoAnnotation
的注解,它有三个元素:author
,version
和 description
。
5.注解的基本语法
@interface 注解名 {
}
**示例代码:**这里使用上一步自定义的注解
@ClassInfoAnnotation(author = "Cheney", description = "This class is Hello")
class Test {public void sayHello(){System.out.println("hello");}
}
在 Test
类上应用了 ClassInfoAnnotation
这个注解,并为元素 author
和 description
赋了值,version
使用默认值。
6.验证注解是否生效
在上面两个步骤中,我们定义了一个自己的注解 ClassInfoAnnotation
,也在 Test
类上应用了,那么这个注解是否生效了呢?是否可以帮助我们做一些事情呢?
例如:打印类的信息(author,version,description)
示例代码:
public static void main(String[] args) {// 获取类上的注解ClassInfoAnnotation anno = Test.class.getAnnotation(ClassInfoAnnotation.class);// 打印注解信息System.out.println("Author: " + anno.author());System.out.println("Version: " + anno.version());System.out.println("Description: " + anno.description());}
输出结果:
Author: Cheney
Version: 1.0.0
Description: This class is Hello
7.注解的使用场景
- 文档生成: 注解可以用于生成文档,例如 Java 中的 Javadoc 工具。
- 编译时检查: 注解可以用于在编译时进行静态检查,提供更严格的类型检查。
- 运行时处理: 注解可以在运行时通过反射进行处理,实现动态操作。
- 代码分析工具: 注解可以被代码分析工具用来检查和验证代码。
- 框架和库: 许多框架和库使用注解来配置和扩展功能,例如 Spring 框架中的注解驱动开发。
8.注解的注意事项
- 注解本身并不影响程序的实际逻辑,它只是提供了一些额外的元数据信息。
- 注解可以包含元素,元素的值可以是基本类型、字符串、枚举、注解或以上类型的数组。
- 注解的使用需要通过反射或其他工具进行处理。
- 注解的定义和使用应遵循一定的规范和命名规则。
结语
Java 注解是一种强大的元数据机制,它在代码中提供了一种轻量级的、结构化的方式来添加额外的信息。通过合理地使用注解,开发者可以提高代码的可读性、可维护性,并在一些特定场景中实现更加灵活和强大的功能。