直接上代码,注释中有说明:
1、定义自定义注解类(类注解和字段注解):
- package com.uno.ray;
- import java.lang.annotation.Documented;
- import java.lang.annotation.ElementType;
- import java.lang.annotation.Inherited;
- import java.lang.annotation.Retention;
- import java.lang.annotation.RetentionPolicy;
- import java.lang.annotation.Target;
- import java.net.Authenticator.RequestorType;
- /**
- * 自定义注解
- * @author Uno
- *@Documented:指明该注解可以用于生成doc
- *@Inherited:该注解可以被自动继承
- *@Retention:指明在什么级别显示该注解:
- * RetentionPolicy.SOURCE 注解存在于源代码中,编译时会被抛弃
- RetentionPolicy.CLASS 注解会被编译到class文件中,但是JVM会忽略
- RetentionPolicy.RUNTIME JVM会读取注解,同时会保存到class文件中
- @Target:指明该注解可以注解的程序范围
- ElementType.TYPE 用于类,接口,枚举但不能是注解
- ElementType.FIELD 作用于字段,包含枚举值
- ElementType.METHOD 作用于方法,不包含构造方法
- ElementType.PARAMETER 作用于方法的参数
- ElementType.CONSTRUCTOR 作用于构造方法
- ElementType.LOCAL_VERIABLE 作用于本地变量或者catch语句
- ElementType.ANNOTATION_TYPE 作用于注解
- ElementType.PACKAGE 作用于包
- */
- @Documented
- @Inherited
- @Retention(RetentionPolicy.RUNTIME)
- @Target({ElementType.TYPE, ElementType.FIELD})//次注解作用于类和字段上
- public @interface FieldTypeAnnotation {
- /**
- *leip 2016年12月3日
- *TODO
- **/
- String type() default "ignore";
- int age() default 27;
- String[] hobby(); //没有指定defalut的,需要在注解的时候显式指明
- }
2、(方法注解)
- package com.uno.ray;
- import java.lang.annotation.Documented;
- import java.lang.annotation.ElementType;
- import java.lang.annotation.Inherited;
- import java.lang.annotation.Retention;
- import java.lang.annotation.RetentionPolicy;
- import java.lang.annotation.Target;
- /**
- *
- * @author Uno
- *
- */
- @Documented
- @Inherited
- @Retention(RetentionPolicy.RUNTIME)
- @Target(ElementType.METHOD) //次注解只能作用于方法上
- public @interface MethodAnnotation {
- String desc() default "method1";
- }
3、定义测试类:(反射类)
- package com.uno.ray;
- import java.awt.Dialog.ModalityType;
- import java.lang.reflect.Field;
- import java.lang.reflect.Method;
- import java.util.Arrays;
- @FieldTypeAnnotation(type = "class", hobby = { "smoke" })
- public class ReflectAnnotation {
- /**
- * leip 2016年12月3日 TODO
- **/
- @FieldTypeAnnotation(hobby = { "sleep", "play" })
- private String maomao;
- @FieldTypeAnnotation(hobby = { "phone", "buy" }, age = 27, type = "normal")
- private String zhangwenping;
- @MethodAnnotation()
- public void method1() {
- }
- @MethodAnnotation(desc="method2")
- public void method2() {
- }
- public static void main(String[] args) {
- // 此处要用反射将字段中的注解解析出来
- Class<ReflectAnnotation> clz = ReflectAnnotation.class;
- // 判断类上是否有次注解
- boolean clzHasAnno = clz.isAnnotationPresent(FieldTypeAnnotation.class);
- if (clzHasAnno) {
- // 获取类上的注解
- FieldTypeAnnotation annotation = clz.getAnnotation(FieldTypeAnnotation.class);
- // 输出注解上的属性
- int age = annotation.age();
- String[] hobby = annotation.hobby();
- String type = annotation.type();
- System.out.println(clz.getName() + " age = " + age + ", hobby = " + Arrays.asList(hobby).toString() + " type = " + type);
- }
- // 解析字段上是否有注解
- // ps:getDeclaredFields会返回类所有声明的字段,包括private、protected、public,但是不包括父类的
- // getFields:则会返回包括父类的所有的public字段,和getMethods()一样
- Field[] fields = clz.getDeclaredFields();
- for(Field field : fields){
- boolean fieldHasAnno = field.isAnnotationPresent(FieldTypeAnnotation.class);
- if(fieldHasAnno){
- FieldTypeAnnotation fieldAnno = field.getAnnotation(FieldTypeAnnotation.class);
- //输出注解属性
- int age = fieldAnno.age();
- String[] hobby = fieldAnno.hobby();
- String type = fieldAnno.type();
- System.out.println(field.getName() + " age = " + age + ", hobby = " + Arrays.asList(hobby).toString() + " type = " + type);
- }
- }
- //解析方法上的注解
- Method[] methods = clz.getDeclaredMethods();
- for(Method method : methods){
- boolean methodHasAnno = method.isAnnotationPresent(MethodAnnotation.class);
- if(methodHasAnno){
- //得到注解
- MethodAnnotation methodAnno = method.getAnnotation(MethodAnnotation.class);
- //输出注解属性
- String desc = methodAnno.desc();
- System.out.println(method.getName() + " desc = " + desc);
- }
- }
- }
- }
4、输出
- com.uno.ray.ReflectAnnotation age = 27, hobby = [smoke] type = class
- maomao age = 27, hobby = [sleep, play] type = ignore
- zhangwenping age = 27, hobby = [phone, buy] type = normal
- method2 desc = method2
- method1 desc = method1
相关推荐
本主题将深入探讨如何在Spring Boot工程中通过自定义response注解、利用Java反射机制、设置自定义拦截器以及实现WebMvcConfigurer接口来实现这一目标。 首先,我们来看自定义response注解。在Spring Boot中,可以...
- **运行时反射**:除了编译时处理,还可以在运行时通过反射获取注解的值,如`MyAnnotation myAnno = field.getAnnotation(MyAnnotation.class); String value = myAnno.value();` 3. **工具支持**: - **Apache ...
Java自定义注解是Java平台提供的一种元编程机制,它允许程序员在源代码中的任何元素(类、方法、变量等)上添加元数据。自定义注解可以被编译器或者运行时系统用来执行特定的任务,例如代码分析、性能监控、持久化...
本文将深入探讨如何通过Java反射来动态修改注解的某个属性值。 首先,了解注解的基本结构。注解是由`@`符号开始,后面跟着注解的名称和一组键值对组成的。例如,自定义注解`@MyAnnotation(name="test")`,其中`name...
在Java编程语言中,自定义注解(Custom Annotation)是一种元数据,允许程序员在代码中添加额外的信息,这些信息可以在编译时或运行时被工具或JVM读取和处理。自定义注解使得代码更加模块化,可读性更强,并且能够...
4. **反射处理**: 遍历DataModel类的所有字段,通过反射获取带有`@ExcelHeader`注解的字段,提取其注解中的name属性作为表头名称。 5. **创建Excel**: 使用Apache POI或JXLS等库创建Excel工作簿,设置表头和数据。...
在上面的代码中,我们使用了 Java 的反射机制来获取注解的值。 结论 Java 注解之运行时修改字段的注解值操作是非常有用的技术,可以帮助我们在实际开发中更方便地处理和修改代码。本文主要介绍了 Java 注解之运行...
本篇文章将深入探讨Java反射机制,并通过自定义框架的测试代码来进一步理解其应用。 首先,我们需要了解什么是反射。在Java中,反射是指在运行时,程序可以获取类、接口、字段和方法的信息,并且能够调用这些方法,...
然而,当我们通过反射获取类的属性时,可能会遇到一个常见的问题:属性的顺序并不总是按照我们期望的方式呈现。默认情况下,Java反射API(如`Field[] getDeclaredFields()`方法)返回的字段数组顺序与它们在源代码中...
在Java中,注解(Annotation)是一种元数据,它提供了将信息附加到代码(类、方法、变量等)的方式,而反射则允许我们在运行时检查类、接口、字段和方法的属性,并能动态调用方法或访问字段。 注解的作用主要有以下...
例如,你可以检查一个类、方法或字段是否被特定的注解标记,并获取注解的值。以下是一个简单的示例: ```java Method method = MyClass.class.getMethod("myMethod"); MethodInfo methodInfo = method....
标题中的“在自定义Spring AOP中使用EL获取拦截方法的变量值”指的是在Spring的面向切面编程(AOP)中,通过Expression Language(EL,表达式语言)来访问被拦截方法的局部变量值。这通常涉及到Spring的代理机制、...
然后,通过反射获取注解的值,并根据这些信息注册Servlet。这使得我们的代码更加模块化,也便于使用依赖注入和其他高级功能。 此外,我们还可以使用`java.lang.reflect`包中的类,如`Class`、`Method`和`Field`,在...
下面我们将深入探讨这两个概念,并通过一个案例来展示它们的使用。 首先,让我们理解反射的概念。反射允许程序动态地获取关于类型、方法、属性等信息,并能在运行时创建和调用对象。在C#中,`System.Reflection`...
1. 定义注解:首先,创建自定义注解来标识需要注入的属性,如`@InjectDependency`。 2. 创建扫描器:编写一个类来扫描所有带有注解的类,收集这些类的信息,包括类名、字段名和注解。 3. 实现注入逻辑:创建一个类或...
属性值可以通过反射API访问,如`annotationInstance.value()`。 4. **元注解** - **元注解**是对注解的注解,提供了关于注解如何使用的附加信息。例如: - **@Retention**:控制注解的生命周期,是只在源代码中...
2. 创建一个读取方法,遍历类的字段,通过反射获取`@ExcelColumn`注解,然后从Excel文件的相应列读取数据并填充到对象中。 3. 创建一个写入方法,反向操作,遍历对象的所有字段,根据注解找到对应的列,将数据写入...
在Java中,我们可以通过定义自定义注解来标记类、方法、字段等,然后通过处理器或反射机制来解析这些注解并采取相应行动。 例如,我们可以创建一个`@Table`注解来标识一个类代表数据库中的表,一个`@Column`注解来...
`@Retention(RetentionPolicy.RUNTIME)`表示这个注解将在运行时保留,这样就可以在运行时通过反射机制获取并处理这些注解。 3. `@Constraint`: 这是一个关键的元注解,它表明`IsValidString`是一个验证约束。`@...