广告
返回顶部
首页 > 资讯 > 精选 >Java中的注解和反射怎么使用
  • 796
分享到

Java中的注解和反射怎么使用

2023-07-02 11:07:48 796人浏览 独家记忆
摘要

这篇文章主要讲解了“Java中的注解和反射怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中的注解和反射怎么使用”吧!1、注解(Annotation)1.1 什么是注解(Ann

这篇文章主要讲解了“Java中的注解和反射怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中的注解和反射怎么使用”吧!

1、注解(Annotation)

1.1 什么是注解(Annotation)

注解不是程序本身,可以在程序编译、类加载和运行时被读取,并执行相应的处理。注解的格式为"@注释名(参数值)",可以附加在包、类、方法和字段上,通过反射机制实现实现注解的访问。

1.2 内置注解

@Override:限定子类重写方法

该注解表示覆盖的是其父类的方法,当子类重写父类方法时,确保子类确实重写了父类的方法,避免出现低级错误

@Overridepublic String toString() {    return super.toString();}

@Deprecated:标记已过时

该注解表示某个属性、方法或类等已过时(程序员不鼓励使用的程序元素,通常是因为它是危险的,或者因为存在更好的替代方法),当其他程序使用已过时的属性、方法或者类时,编译器会给出警告(删除线)。

@Deprecatedpublic static void test() {    System.out.println("标记已过时");}

@SuppressWarnings(参数):抑制编译器警告

该注解作用的类、方法和属性会取消显示编译器警告,其参数主要是进行警告说明以及取消(unchecked)等。

@SuppressWarnings("取消此类的所有警告")public class BuiltAnnotation {        @SuppressWarnings("取消此属性的警告")    private String username;    @SuppressWarnings("取消此方法的警告")    public static void main(String[] args) {        // ...    }}

1.3 元注解(meta-annotation)

元注解的作用就是负责注解其他注解,Java定义了4个标准的元注解类型,他们被用来提供对其他注解的作用范围及类型进行说明,通过元注解可以自定义其他注解。

@Target:描述注解的使用范围

例如@Target(ElementType.METHOD)表示作用在方法上,@Target(ElementType.TYPE)表示作用在类或接口上等

@Documented@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.ANNOTATION_TYPE)public @interface Target {        ElementType[] value();}

@Retention:表示需要在什么级别保存该注解信息,用于描述注解的生命周期

通常自定义的注解都使用@Retention(RetentionPolicy.RUNTIME),也就是运行时期作用。

@Documented@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.ANNOTATION_TYPE)public @interface Retention {        RetentionPolicy value();}

@Document:说明该注将被包含在javadoc中

@Iherited:定义子类是否可继承父类定义的注解。

@Inherited仅针对 @Target(ElementType.TYPE) 类型的注解有用,并且只能是 class 的继承,对 interface 的继承无效:

1.4 自定义注解

定义注解

@Target({ElementType.METHOD, ElementType.TYPE})@Retention(RetentionPolicy.RUNTIME)public @interface Report{        int type() default 0;    String value() default "LonerMJ";}

使用注解

@Report(type = 1, value = "test")public class CustomerAnnotation {    @Report(type = 1, value = "test")    public void testCustomerAnnotation() {        System.out.println("测试自定义注解");    }}

2、反射(Reflection)

2.1 反射和反射机制

反射

Reflection(反射)是指程序在运行期可以拿到一个对象的所有信息。

反射机制

反射机制是指程序在运行时,通过Reflection api获取任何类的内容信息,并能直接操作任何对象的内部属性及方法。

2.2 Class类的获取方式和常用方法

java.lang.Class类,实现反射的核心类,类加载完成之后,在堆内存的方法区中就会产生一个Class对象(一个类只有一个Class对象),这个对象包含了类的完整结构信息,通过这个对象看到类的结构。

Class类的获取方式

public class InstantiationClass {    public static void main(String[] args) throws ClassNotFoundException {        Teacher teacher = new Teacher("张三", "123456");        // 方式一:调用Class类的静态方法forName(String className)        Class<?> c1 = Class.forName("com.loner.mj.reflection.Teacher");        // 方式二:已知某个类的实例,调用该实例的getClass()方法,getClass是Object类中的方法。        Class<? extends Teacher> c2 = teacher.getClass();        // 方式三:已知具体类,通过类的class属性获取,该方法最安全可靠,程序性能最高        Class<Teacher> c3 = Teacher.class;        // 方式四:通过基本内置类型的包装类的TYPE属性获得CLass实例        Class<Integer> c4 = Integer.TYPE;        // 方式五:通过当前子类的Class对象获得父类的Class对象        Class<?> c5 = c1.getSuperclass();    }}

Class类的常用方法

方法名方法功能
static Class forName(String name)返回指定类名的Class对象
Obiect newInstance()调用无参构造函数,返回Class对象的一个实例
String getName()返回此Class对象所表示的实体(类,接口,数组类或void)的名称
Class getSuperclass()返回当前Class对象的父类的Class对象
Class[] getinterfaces()返回当前Class对象的接口
ClassLoader getClassLoader()返回该类的类加载器
Method getDeclareMethod(String name, Class<?> ... parameterTypes)获取方法名和参数列表匹配的方法
Method[] getDeclareMethods()获取所有非继承的方法
Method[] getMethods()获取所有非私有方法
Field getDeclareField(String name)获取指定属性
Field[] getDeclareFields()获取所有属性
Field[] getFields()获取所有非私有属性
Constructor getConstructor(Class<?>... parameterTypes获取参数列表匹配的构造方法
Constructor getConstructors()获取类的所有构造方法
A getAnnotation(Class<?> annotationClass)返回指定注解
Annotation[] getDeclaredAnnotations()返回所有注解
public class ReflectionMethods {    public static void main(String[] args) throws NoSuchFieldException, NoSuchMethodException {        Class<Worker> workerClass = Worker.class;                System.out.println(workerClass.getName());        System.out.println(workerClass.getSimpleName());        System.out.println(workerClass.getSuperclass());        System.out.println(workerClass.getPackage());        Class<?>[] interfaces = workerClass.getInterfaces();        for (Class<?> i : interfaces) {            System.out.println(i);        }                // 获取所有的属性        Field[] declaredFields = workerClass.getDeclaredFields();        for (Field declaredField : declaredFields) {            System.out.println(declaredField);        }        // 获取指定属性        System.out.println(workerClass.getDeclaredField("username"));        // 获取所有公共属性        Field[] fields = workerClass.getFields();        for (Field field : fields) {            System.out.println(field);        }                // 获取所有构造方法        Constructor<?>[] declaredConstructors = workerClass.getDeclaredConstructors();        for (Constructor<?> declaredConstructor : declaredConstructors) {            System.out.println(declaredConstructor);        }        // 获取指定的构造方法        System.out.println(workerClass.getDeclaredConstructor(String.class, String.class));                // 获取所有的方法        Method[] declaredMethods = workerClass.getDeclaredMethods();        for (Method declaredMethod : declaredMethods) {            System.out.println(declaredMethod);        }        // 获取指定方法        System.out.println(workerClass.getDeclaredMethod("getUsername", null));        // 获取所有功能方法        Method[] methods = workerClass.getMethods();        for (Method method : methods) {            System.out.println(method);        }    }}

哪些类型具有Class对象

public class InstantiationClass {    public static void main(String[] args) throws ClassNotFoundException {        // 类(外部类,成员(成员内部类,静态内部类),局部内部类,匿名内部类。)        Class<Object> objectClass = Object.class;        // 接口        Class<Comparable> comparableClass = Comparable.class;        // 数组        Class<String[]> strinGClass = String[].class;        Class<int[][]> intClass = int[][].class;        // 枚举        Class<ElementType> elementTypeClass = ElementType.class;        // 注解        Class<Override> overrideClass = Override.class;        // 基本数据类型        Class<Integer> integerClass = Integer.class;        // void        Class<Void> voidClass = void.class;        // Class        Class<Class> classClass = Class.class;    }}

2.3 反射的使用

反射操作对象

public class UseClass {    public static void main(String[] args) throws NoSuchMethodException, InvocationTargetException, InstantiationException, IllegalAccessException, NoSuchFieldException {        Class<User> userClass = User.class;                Constructor<User> declaredConstructor = userClass.getDeclaredConstructor(String.class, String.class);        User user = declaredConstructor.newInstance("张三", "123456");        System.out.println(user);                Method setUsername = userClass.getDeclaredMethod("setUsername", String.class);        // invoke(Object, 参数):激活,即执行相关操作为该对象        setUsername.invoke(user, "李四");        Method setPassWord = userClass.getDeclaredMethod("setPassword", String.class);        setPassword.invoke(user, "123456");        System.out.println(user);                Field username = userClass.getDeclaredField("username");        username.setAccessible(true);        username.set(user, "用户名");        System.out.println(user);    }}

反射操作泛型

Java采用泛型擦除的机制来引入泛型,Java中的泛型仅仅是给编译器javac使用的,确保数据的安全性和免去强制类型转换问题。但是,一旦编译完成,所有和泛型有关的类型全部擦除。

为了通过反射操作这些类型,Java新增了ParameterizedType,GenericArrayType,TypeVariable和WildcardType几种类型来代表不能被归一到Class类中的类型但是又和原始类型齐名的类型。

ParameterizedType:表示一种参数化类型,比如Collection

GenericArrayType:表示一种元素类型是参数化类型或者类型变量的数组类型

TypeVariable:是各种类型变量的公共父接口

WildcardType:代表一种通配符类型表达式

public class ClassOperateGenerics {    public Map<String, String> list() {        System.out.println("返回值是泛型");        return new HashMap<>();    }    public void test(Map<String, User> map, List<Integer> list) {        System.out.println("参数是泛型");    }    public static void main(String[] args) throws NoSuchMethodException {                Method method = ClassOperateGenerics.class.getMethod("test", Map.class, List.class);        // 获取所有方法参数的泛型        Type[] genericParameterTypes = method.getGenericParameterTypes();        for (Type genericParameterType : genericParameterTypes) {            // java.util.Map<java.lang.String, com.loner.mj.reflection.User>            System.out.println(genericParameterType);            if (genericParameterType instanceof ParameterizedType) {                // 获取所有泛型的真实参数                Type[] actualTypeArguments = ((ParameterizedType) genericParameterType).getActualTypeArguments();                for (Type actualTypeArgument : actualTypeArguments) {                    // String, User, Integer                    System.out.println(actualTypeArgument);                }            }        }                Method list = ClassOperateGenerics.class.getMethod("list", null);        // 获取方法返回值的泛型        Type genericReturnType = list.getGenericReturnType();        if (genericReturnType instanceof ParameterizedType) {            // 获取所有泛型的真实参数            Type[] actualTypeArguments = ((ParameterizedType) genericReturnType).getActualTypeArguments();            for (Type actualTypeArgument : actualTypeArguments) {                System.out.println(actualTypeArgument);            }        }    }}

反射操作注解

public class ClassOperateAnnotation {    public static void main(String[] args) throws NoSuchFieldException {        Class<People> peopleClass = People.class;        // 获取类的所有注解        Annotation[] declaredAnnotations = peopleClass.getDeclaredAnnotations();        for (Annotation declaredAnnotation : declaredAnnotations) {            System.out.println(declaredAnnotation);        }        // 获取类的注解的值        Table declaredAnnotation = peopleClass.getDeclaredAnnotation(Table.class);        System.out.println(declaredAnnotation.value());        // 获取属性的注解        Field name = peopleClass.getDeclaredField("name");        Fields annotation = name.getAnnotation(Fields.class);        System.out.println(annotation.name());    }}

感谢各位的阅读,以上就是“Java中的注解和反射怎么使用”的内容了,经过本文的学习后,相信大家对Java中的注解和反射怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Java中的注解和反射怎么使用

本文链接: https://www.lsjlt.com/news/341554.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java中的注解和反射怎么使用
    这篇文章主要讲解了“Java中的注解和反射怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中的注解和反射怎么使用”吧!1、注解(Annotation)1.1 什么是注解(Ann...
    99+
    2023-07-02
  • java注解和反射怎么使用
    Java注解和反射是Java编程中非常重要的概念。注解是一种元数据,可以用来为Java程序提供额外的信息,而反射则允许程序在运行时动...
    99+
    2023-05-29
    java注解和反射 java
  • java中反射和注解的简单使用方法
    目录什么反射?Java反射机制提供的功能反射相关的主要APIClass 类获取Class 类的实例( 四种方法)哪些类型可以有Class 对象?演示Class类的常用方法有了Clas...
    99+
    2022-11-12
  • 如何在Java项目中使用注解和反射
    今天就跟大家聊聊有关如何在Java项目中使用注解和反射,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java可以用来干什么Java主要应用于:1. web开发;2. Android开...
    99+
    2023-06-06
  • Java的枚举,注解和反射(一)
    目录枚举什么是枚举?枚举类的实现自定义实现枚举类使用关键字enum定义枚举类Enum的常用方法实现接口的枚举类注解注解概述常见的注解总结枚举 什么是枚举? 枚举的字面意思就是 一一列...
    99+
    2022-11-12
  • Java的枚举,注解和反射(二)
    目录反射什么是反射?反射的用途反射的具体作用反射的主要APIClass类总结反射 什么是反射? 反射是指在程序运行期间,可以通过Reflection Api提供方法可以获取任何类的内...
    99+
    2022-11-12
  • 一文搞懂Java中的注解和反射
    目录1、注解(Annotation)1.1 什么是注解(Annotation)1.2 内置注解1.3 元注解(meta-annotation)1.4 自定义注解2、反射(Reflec...
    99+
    2022-11-13
  • 怎么用java反射给属性加注解
    在Java中,无法直接使用反射给属性添加注解。注解只能在编译期间被处理,而反射是在运行时动态获取和操作类的信息。因此,无法通过反射来...
    99+
    2023-10-22
    java
  • Java项目中的注解怎么利用反射机制读取
    这篇文章将为大家详细讲解有关Java项目中的注解怎么利用反射机制读取,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、自定义注解元注解: @interface注解: 定义注解接口@Targe...
    99+
    2023-05-31
    java ava
  • 如何使用Java注解和反射实现Junit4中的用例调用
    这篇文章主要讲解了“如何使用Java注解和反射实现Junit4中的用例调用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用Java注解和反射实现Junit4中的用例调用”吧!实例需求需...
    99+
    2023-06-15
  • 如何用Java注解和反射实现依赖注入
    目录概述定义注解为被注入的方法添加注解通过反射处理注解概述 在Spring中,我们可以通过 @Autowired注解的方式为一个方法中注入参数,那么这种方法背后到底发生了什么呢,这篇...
    99+
    2022-11-12
  • java高级用法之注解和反射讲义
    前言 反射和注解在java中偏高级用法,一般在各种框架中被广泛应用,文章简单介绍下反射和注解的用法,希望对你的工作学习有一定帮助 java注解 什么是注解 Java 注解也就是An...
    99+
    2022-11-12
  • JAVA基础之注解与反射的使用方法和场景
    目录注解注解定义使用场景内置注解 元注解反射加载配置文件反射获取Class反射获取 Constructor反射获取 Method反射获取 Field通过反射获取注解信息内省...
    99+
    2022-11-11
  • Java反射机制怎么使用
    今天小编给大家分享一下Java反射机制怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。反射的概述JAVA反射机制是在运...
    99+
    2023-06-30
  • Java怎么使用反射和动态代理实现一个View注解绑定库
    本篇内容介绍了“Java怎么使用反射和动态代理实现一个View注解绑定库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用反射结合动态代理实...
    99+
    2023-06-30
  • Java中反射机制和作用详解
    前言 很多刚学Java反射的同学可能对反射技术一头雾水,为什么要学习反射,学习反射有什么作用,不用反射,通过new也能创建用户对象。 那么接下来大师就带你们了解一下反射是什么,为什么...
    99+
    2022-11-12
  • Java反射的setAccessible()方法怎么使用
    本篇内容介绍了“Java反射的setAccessible()方法怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、 什么是Java的...
    99+
    2023-07-02
  • Java高级特性中的泛型、反射和注解该如何理解
    这篇文章跟大家分析一下“Java高级特性中的泛型、反射和注解该如何理解”。内容详细易懂,对“Java高级特性中的泛型、反射和注解该如何理解”感兴趣的朋友可以跟着小编的思路慢慢深入来阅读一下,希望阅读后能够对大家有所帮助。下面跟着小编一起深入...
    99+
    2023-06-16
  • 一文带你了解java中的泛型、反射与注解
    一文带你了解java中的泛型、反射与注解?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。泛型擦除泛型擦除: 泛型只在编译时期有效,编译后的字节码文件中不存在泛型信息。声明泛型...
    99+
    2023-05-31
    java 反射 泛型
  • Java基础之反射怎么使用
    本篇内容介绍了“Java基础之反射怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!反射是框架设计的灵魂(使用的前提条件:必须先得到代表...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作