JavaSE--注解
一、注解
1、注解概述
注解,又叫叫做注释类型,Annotation
注解Annotation是一种引用数据类型。编译之后也是生成xxx.class文件。
2、语法格式
// 定义语法格式 [修饰符列表] @interface 注解类型名{ } // 使用时语法格式 @注解类型名
public @interface MyAnnotation{ }
3、注解使用地方
注解可以出现在类上、属性上、方法上、变量上等....注解还可以出现在注解类型上。
默认情况下,注解可以出现在任何位置
@MyAnnotation public class AnnotationTest01 { @MyAnnotation private int no; @MyAnnotation public AnnotationTest01(){} @MyAnnotation public static void m1(){ @MyAnnotation int i = 100; } @MyAnnotation public void m2(@MyAnnotation String name, @MyAnnotation int k){ } } @MyAnnotation interface MyInterface { } @MyAnnotation enum Season { SPRING,SUMMER,AUTUMN,WINTER }
4、jdk内置的注解
jdk的java.lang包下的
Deprecated 用 @Deprecated 注释的程序元素,不鼓励程序员使用这样的元素,通常是因为它很危险或存在更好的选择(也就是一般用这个的话,就是这个元素已经淘汰了,有更好的代替元素来使用)
Override 表示一个方法声明打算重写超类中的另一个方法声明。
SuppressWarnings 指示应该在注释元素(以及包含在该注释元素中的所有程序元素)中取消显示指定的编译器警告(不用掌握)
1)@Override
@Override这个注解是一个标识性注解,给编译器做参考的。编译器看到方法上有这个注解的时候,编译器会自动检查该方法是否重写了父类的方法。如果没有重写,报错。和运行阶段没有关系
@Override只能注解方法
// 源代码 public @interface Override { }
public class AnnotationTest02 { private int no; @Override public String toString() { return "toString方法重写"; } }
2)@Deprecated
Deprecated这个注解标注的元素已过时。
这个注解主要是向其它程序员传达一个信息,告知已过时,有更好的解决方案存在
@Deprecated public static void doOther(){ System.out.println("do other..."); } // 类上也可以
5、元注解
1)元注解概述
用来标注“注解类型”的“注解”,称为元注解
2)常见的元注解
Target、Retention
3)Target注解
Target注解用来标注“被标注的注解”可以出现在哪些位置上
// 表示“被标注的注解”只能出现在方法上。 @Target(ElementType.METHOD) // 表示该注解可以出现在:构造方法上、字段上、局部变量上、方法上、包上、......类上... @Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, MODULE, PARAMETER, TYPE})
4)Retention注解
Retention注解用来标注“被标注的注解”最终保存在哪里
// 表示该注解只被保留在java源文件中 @Retention(RetentionPolicy.SOURCE) // 表示该注解被保存在class文件中 @Retention(RetentionPolicy.CLASS) // 表示该注解被保存在class文件中,并且可以被反射机制所读取 @Retention(RetentionPolicy.RUNTIME)
二、自定义注解
1、定义属性
public @interface MyAnnotation { /** * 我们通常在注解当中可以定义属性,以下这个是MyAnnotation的name属性 * 看着像1个方法,但实际上我们称之为属性name。 * @return */ String name(); /* 颜色属性 */ String color(); /* 年龄属性 */ int age() default 25; //属性指定默认值,指定默认值,使用的时候可以不写 /* 数组String 邮箱地址属性 */ String[] email(); }
public class MyAnnotationTest { //如果一个注解当中有属性,那么必须给属性赋值。(除非该属性使用default指定了默认值) //@MyAnnotation(属性名=属性值,属性名=属性值,属性名=属性值) @MyAnnotation(name = "zhangsan", color = "红色", email = {"lsdk","ddf"}) public void doSome(){ } // 数组中元素只有一个的话,可以不写{ }大括号 @MyAnnotation(name = "zhangsan", color = "红色", email = "lsdk") public void doOther(){ } }
2、定义value属性
如果一个注解的属性的名字时value的话,并且只有这一个属性,在使用的时候value属性名可以省略不写
public @interface MyAnnotation { /* value属性 */ String value(); }
public class MyAnnotationTest { @MyAnnotation("hh") public void doSome(){ } }
3、注解中属性的数据类型
byte short int long float double boolean char String Class 枚举类型 以及他们每一种的数组形式
public @interface MyAnnotation { int value1(); String value2(); int[] value3(); String[] value4(); // 枚举 Season value5(); // 枚举数组 Season[] value6(); Class parameterType(); Class[] parameterTypes(); }
三、反射注解
通过反射机制获取注解,并且获取注解中的属性值
// 自定义注解 @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface MyAnnotation { /* username属性 */ String username(); /* password属性 */ String password(); }
public class MyAnnotationTest { @MyAnnotation(username = "admin", password = "123123") public void doSome(){ } public static void main(String[] args) throws Exception{ // 获取MyAnnotationTest的doSome()方法上面的注解信息 // 先获取类 Class c = Class.forName("com.bjpowernode.java.annotation6.MyAnnotationTest"); // 再获取doSome()方法 Method doSomeMethod = c.getDeclaredMethod("doSome"); // 判断该方法上是否存在这个注解isAnnotationPresent(MyAnnotation.class) if(doSomeMethod.isAnnotationPresent(MyAnnotation.class)) { // 获取注解 MyAnnotation myAnnotation = doSomeMethod.getAnnotation(MyAnnotation.class); // 通过注解.点的方式 获取注解的属性值 System.out.println(myAnnotation.username()); System.out.println(myAnnotation.password()); } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?