java获取类结构信息

news2024/9/23 11:12:51
  1. package com.hspedu.reflection;
    
    import org.junit.jupiter.api.Test;
    
    import java.lang.annotation.Annotation;
    import java.lang.reflect.Constructor;
    import java.lang.reflect.Field;
    import java.lang.reflect.Method;
    
    /**
     * @author 韩顺平
     * @version 1.0
     * 演示如何通过反射获取类的结构信息
     */
    public class ReflectionUtils {
        public static void main(String[] args) {
    
        }
    
        @Test
        public void api_02() throws ClassNotFoundException, NoSuchMethodException {
            //得到Class对象
            Class<?> personCls = Class.forName("com.hspedu.reflection.Person");
            //getDeclaredFields:获取本类中所有属性
            //规定 说明: 默认修饰符 是0 , public  是1 ,private 是 2 ,protected 是 4 , static 是 8 ,final 是 16
            Field[] declaredFields = personCls.getDeclaredFields();
            for (Field declaredField : declaredFields) {
                System.out.println("本类中所有属性=" + declaredField.getName()
                        + " 该属性的修饰符值=" + declaredField.getModifiers()
                        + " 该属性的类型=" + declaredField.getType());
            }
    
            //getDeclaredMethods:获取本类中所有方法
            Method[] declaredMethods = personCls.getDeclaredMethods();
            for (Method declaredMethod : declaredMethods) {
                System.out.println("本类中所有方法=" + declaredMethod.getName()
                        + " 该方法的访问修饰符值=" + declaredMethod.getModifiers()
                        + " 该方法返回类型" + declaredMethod.getReturnType());
    
                //输出当前这个方法的形参数组情况
                Class<?>[] parameterTypes = declaredMethod.getParameterTypes();
                for (Class<?> parameterType : parameterTypes) {
                    System.out.println("该方法的形参类型=" + parameterType);
                }
            }
    
            //getDeclaredConstructors:获取本类中所有构造器
            Constructor<?>[] declaredConstructors = personCls.getDeclaredConstructors();
            for (Constructor<?> declaredConstructor : declaredConstructors) {
                System.out.println("====================");
                System.out.println("本类中所有构造器=" + declaredConstructor.getName());//这里老师只是输出名
    
                Class<?>[] parameterTypes = declaredConstructor.getParameterTypes();
                for (Class<?> parameterType : parameterTypes) {
                    System.out.println("该构造器的形参类型=" + parameterType);
                }
    
    
    
            }
    
        }
    
        //第一组方法API
        @Test
        public void api_01() throws ClassNotFoundException, NoSuchMethodException {
    
            //得到Class对象
            Class<?> personCls = Class.forName("com.hspedu.reflection.Person");
            //getName:获取全类名
            System.out.println(personCls.getName());//com.hspedu.reflection.Person
            //getSimpleName:获取简单类名
            System.out.println(personCls.getSimpleName());//Person
            //getFields:获取所有public修饰的属性,包含本类以及父类的
            Field[] fields = personCls.getFields();
            for (Field field : fields) {//增强for
                System.out.println("本类以及父类的属性=" + field.getName());
            }
            //getDeclaredFields:获取本类中所有属性
            Field[] declaredFields = personCls.getDeclaredFields();
            for (Field declaredField : declaredFields) {
                System.out.println("本类中所有属性=" + declaredField.getName());
            }
            //getMethods:获取所有public修饰的方法,包含本类以及父类的
            Method[] methods = personCls.getMethods();
            for (Method method : methods) {
                System.out.println("本类以及父类的方法=" + method.getName());
            }
            //getDeclaredMethods:获取本类中所有方法
            Method[] declaredMethods = personCls.getDeclaredMethods();
            for (Method declaredMethod : declaredMethods) {
                System.out.println("本类中所有方法=" + declaredMethod.getName());
            }
            //getConstructors: 获取所有public修饰的构造器,包含本类
            Constructor<?>[] constructors = personCls.getConstructors();
            for (Constructor<?> constructor : constructors) {
                System.out.println("本类的构造器=" + constructor.getName());
            }
            //getDeclaredConstructors:获取本类中所有构造器
            Constructor<?>[] declaredConstructors = personCls.getDeclaredConstructors();
            for (Constructor<?> declaredConstructor : declaredConstructors) {
                System.out.println("本类中所有构造器=" + declaredConstructor.getName());//这里老师只是输出名
            }
            //getPackage:以Package形式返回 包信息
            System.out.println(personCls.getPackage());//com.hspedu.reflection
            //getSuperClass:以Class形式返回父类信息
            Class<?> superclass = personCls.getSuperclass();
            System.out.println("父类的class对象=" + superclass);//
            //getInterfaces:以Class[]形式返回接口信息
            Class<?>[] interfaces = personCls.getInterfaces();
            for (Class<?> anInterface : interfaces) {
                System.out.println("接口信息=" + anInterface);
            }
            //getAnnotations:以Annotation[] 形式返回注解信息
            Annotation[] annotations = personCls.getAnnotations();
            for (Annotation annotation : annotations) {
                System.out.println("注解信息=" + annotation);//注解
            }
    
    
        }
    }
    
    class A {
        public String hobby;
    
        public void hi() {
    
        }
    
        public A() {
        }
    
        public A(String name) {
        }
    }
    
    interface IA {
    }
    
    interface IB {
    
    }
    
    @Deprecated
    class Person extends A implements IA, IB {
        //属性
        public String name;
        protected static int age; // 4 + 8 = 12
        String job;
        private double sal;
    
        //构造器
        public Person() {
        }
    
        public Person(String name) {
        }
    
        //私有的
        private Person(String name, int age) {
    
        }
    
        //方法
        public void m1(String name, int age, double sal) {
    
        }
    
        protected String m2() {
            return null;
        }
    
        void m3() {
    
        }
    
        private void m4() {
    
        }
    }
    
  2. 通过反射创建对象

    package com.hspedu.reflection;
    
    import java.lang.reflect.Constructor;
    import java.lang.reflect.InvocationTargetException;
    
    /**
     * @author 韩顺平
     * @version 1.0
     * 演示通过反射机制创建实例
     */
    public class ReflecCreateInstance {
        public static void main(String[] args) throws ClassNotFoundException, IllegalAccessException, InstantiationException, NoSuchMethodException, InvocationTargetException {
    
            //1. 先获取到User类的Class对象
            Class<?> userClass = Class.forName("com.hspedu.reflection.User");
            //2. 通过public的无参构造器创建实例
            Object o = userClass.newInstance();
            System.out.println(o);
            //3. 通过public的有参构造器创建实例
            /*
                constructor 对象就是
                public User(String name) {//public的有参构造器
                    this.name = name;
                }
             */
            //3.1 先得到对应构造器
            Constructor<?> constructor = userClass.getConstructor(String.class);
            //3.2 创建实例,并传入实参
            Object hsp = constructor.newInstance("hsp");
            System.out.println("hsp=" + hsp);
            //4. 通过非public的有参构造器创建实例
            //4.1 得到private的构造器对象
            Constructor<?> constructor1 = userClass.getDeclaredConstructor(int.class, String.class);
            //4.2 创建实例
            //暴破【暴力破解】 , 使用反射可以访问private构造器/方法/属性, 反射面前,都是纸老虎
            constructor1.setAccessible(true);
            Object user2 = constructor1.newInstance(100, "张三丰");
            System.out.println("user2=" + user2);
        }
    }
    
    class User { //User类
        private int age = 10;
        private String name = "韩顺平教育";
    
        public User() {//无参 public
        }
    
        public User(String name) {//public的有参构造器
            this.name = name;
        }
    
        private User(int age, String name) {//private 有参构造器
            this.age = age;
            this.name = name;
        }
    
        public String toString() {
            return "User [age=" + age + ", name=" + name + "]";
        }
    }
    
  3. 反射爆破操作属性

    package com.hspedu.reflection;
    
    import java.lang.reflect.Field;
    
    /**
     * @author 韩顺平
     * @version 1.0
     * 演示反射操作属性
     */
    public class ReflecAccessProperty {
        public static void main(String[] args) throws ClassNotFoundException, IllegalAccessException, InstantiationException, NoSuchFieldException {
    
            //1. 得到Student类对应的 Class对象
            Class<?> stuClass = Class.forName("com.hspedu.reflection.Student");
            //2. 创建对象
            Object o = stuClass.newInstance();//o 的运行类型就是Student
            System.out.println(o.getClass());//Student
            //3. 使用反射得到age 属性对象
            Field age = stuClass.getField("age");
            age.set(o, 88);//通过反射来操作属性
            System.out.println(o);//
            System.out.println(age.get(o));//返回age属性的值
    
            //4. 使用反射操作name 属性
            Field name = stuClass.getDeclaredField("name");
            //对name 进行暴破, 可以操作private 属性
            name.setAccessible(true);
            //name.set(o, "老韩");
            name.set(null, "老韩~");//因为name是static属性,因此 o 也可以写出null
            //null是所有对象的
            System.out.println(o);
            System.out.println(name.get(o)); //获取属性值
            System.out.println(name.get(null));//获取属性值, 要求name是static
    
        }
    }
    
    class Student {//类
        public int age;
        private static String name;
    
        public Student() {//构造器
        }
    
        public String toString() {
            return "Student [age=" + age + ", name=" + name + "]";
        }
    }
    
    

     

    package com.hspedu.reflection;
    
    import java.lang.reflect.InvocationTargetException;
    import java.lang.reflect.Method;
    
    /**
     * @author 韩顺平
     * @version 1.0
     * 演示通过反射调用方法
     */
    public class ReflecAccessMethod {
        public static void main(String[] args) throws ClassNotFoundException, NoSuchMethodException, IllegalAccessException, InstantiationException, InvocationTargetException {
    
            //1. 得到Boss类对应的Class对象
            Class<?> bossCls = Class.forName("com.hspedu.reflection.Boss");
            //2. 创建对象
            Object o = bossCls.newInstance();
            //3. 调用public的hi方法
            //Method hi = bossCls.getMethod("hi", String.class);//OK
            //3.1 得到hi方法对象
            Method hi = bossCls.getDeclaredMethod("hi", String.class);//OK
            //3.2 调用
            hi.invoke(o, "韩顺平教育~");
    
            //4. 调用private static 方法
            //4.1 得到 say 方法对象
            Method say = bossCls.getDeclaredMethod("say", int.class, String.class, char.class);
            //4.2 因为say方法是private, 所以需要暴破,原理和前面讲的构造器和属性一样
            say.setAccessible(true);
            System.out.println(say.invoke(o, 100, "张三", '男'));
            //4.3 因为say方法是static的,还可以这样调用 ,可以传入null
            System.out.println(say.invoke(null, 200, "李四", '女'));
    
            //5. 在反射中,如果方法有返回值,统一以Object来接收 , 但是他运行类型和方法定义的返回类型一致
            Object reVal = say.invoke(null, 300, "王五", '男');
            System.out.println("reVal 的运行类型=" + reVal.getClass());//String
    
    
            //在演示一个返回的案例
            Method m1 = bossCls.getDeclaredMethod("m1");
            Object reVal2 = m1.invoke(o);
            System.out.println("reVal2的运行类型=" + reVal2.getClass());//Monster
    
    
        }
    }
    
    class Monster {}
    class Boss {//类
        public int age;
        private static String name;
    
        public Boss() {//构造器
        }
    
        public Monster m1() {
            return new Monster();
        }
    
        private static String say(int n, String s, char c) {//静态方法
            return n + " " + s + " " + c;
        }
    
        public void hi(String s) {//普通public方法
            System.out.println("hi " + s);
        }
    }
    
    
  4. 练习

    package com.hspedu.reflection.homework;
    
    import java.lang.reflect.Field;
    import java.lang.reflect.InvocationTargetException;
    import java.lang.reflect.Method;
    
    /**
     * @author 韩顺平
     * @version 1.0
     */
    public class Homework01 {
        public static void main(String[] args) throws IllegalAccessException, InstantiationException, NoSuchFieldException, NoSuchMethodException, InvocationTargetException {
            /**
             * 定义PrivateTest类,有私有name属性,并且属性值为hellokitty
             * 提供getName的公有方法
             * 创建PrivateTest的类,利用Class类得到私有的name属性,修改私有的name属性值,并调用getName()的方法打印name属性值
             */
            //1. 得到 PrivateTest类对应的Class对象
            Class<PrivateTest> privateTestClass = PrivateTest.class;
            //2. 创建对象实例
            PrivateTest privateTestObj = privateTestClass.newInstance();
            //3. 得到name属性对象
            Field name = privateTestClass.getDeclaredField("name");//name属性是private
            //4. 暴破name
            name.setAccessible(true);
            name.set(privateTestObj, "天龙八部");
            //5. 得到getName方法对象
            Method getName = privateTestClass.getMethod("getName");
            //6. 因为getName() 是public,所有直接调用
            Object invoke = getName.invoke(privateTestObj);
            System.out.println("name属性值=" + invoke);//天龙八部
    
        }
    }
    
    class PrivateTest {
        private String name = "hellokitty";
        //默认无参构造器
        public String getName() {
            return name;
        }
    }
    
    

    注意Class对象和创建实例化对象

  5. package com.hspedu.reflection.homework;
    
    import java.lang.reflect.Constructor;
    import java.lang.reflect.InvocationTargetException;
    import java.lang.reflect.Method;
    
    /**
     * @author 韩顺平
     * @version 1.0
     */
    public class Homework02 {
        public static void main(String[] args) throws ClassNotFoundException, NoSuchMethodException, IllegalAccessException, InvocationTargetException, InstantiationException {
            /**
             * 利用Class类的forName方法得到File类的class 对象
             * 在控制台打印File类的所有构造器
             * 通过newInstance的方法创建File对象,并创建E:\mynew.txt文件
             */
            //1. Class类的forName方法得到File类的class 对象
            Class<?> fileCls = Class.forName("java.io.File");
            //2. 得到所有的构造器
            Constructor<?>[] declaredConstructors = fileCls.getDeclaredConstructors();
            //遍历输出
            for (Constructor<?> declaredConstructor : declaredConstructors) {
                System.out.println("File构造器=" + declaredConstructor);
            }
            //3. 指定的得到 public java.io.File(java.lang.String)
            Constructor<?> declaredConstructor = fileCls.getDeclaredConstructor(String.class);
            String fileAllPath = "e:\\mynew.txt";
            Object file = declaredConstructor.newInstance(fileAllPath);//创建File对象
    
            //4. 得到createNewFile 的方法对象
            Method createNewFile = fileCls.getMethod("createNewFile");
            createNewFile.invoke(file);//创建文件,调用的是 createNewFile
            //file的运行类型就是File
            System.out.println(file.getClass());
            System.out.println("创建文件成功" + fileAllPath);
    
        }
    }
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/464880.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

初级算法-回溯算法

主要记录算法和数据结构学习笔记&#xff0c;新的一年更上一层楼&#xff01; 初级算法-回溯算法 一、组合二、电话号码的字母组合三、组合总和四、组合Ⅱ五、组合Ⅲ六、分割回文串七、复原IP地址八、子集问题九、子集Ⅱ十、递增子序列十一、重新安排行程十二、全排列十三、全…

CASAIM自动化精密尺寸测量设备全尺寸检测铸件自动化检测铸件

铸造作为现代装备制造工业的基础共性技术之一&#xff0c;铸件产品既是工业制造产品&#xff0c;也是大型机械的重要组成部分&#xff0c;被广泛运用在航空航天、工业船舶、机械电子和交通运输等行业。 铸件形状复杂&#xff0c;一般的三坐标或者卡尺圆规等工具难以获取多特征…

【基础算法】八大排序算法:直接插入排序,希尔排序,选择排序,堆排序,冒泡排序,快速排序(快排),归并排序,计数排序

文章目录 ✔️前言直接插入排序希尔排序选择排序1. 选择排序基础2. 选择排序优化3. 复杂度的分析 堆排序【⭐重点掌握⭐】1. 对堆的认识和数组建堆2. 对数组进行堆排序操作3. 复杂度的分析 冒泡排序快速排序【⭐重点掌握⭐】1. 霍尔法2. 挖坑法3. 前后指针法4. 快速排序优化&am…

每日一个小技巧:1招教你提取伴奏怎么做

伴奏是指在演唱或演奏时&#xff0c;用来衬托或补充主唱或乐器的音乐声音。而伴奏提取是一种技术&#xff0c;它可以帮助我们从歌曲中将人声和乐器分离出来。当我们听到一些喜欢的歌曲时&#xff0c;往往会被它的旋律深深吸引&#xff0c;想要将其作为自己的演唱曲目&#xff0…

国考只考一门?免试入学还好毕业的在职研究生专业有哪些

读同等学力申硕的同学想要拿学位证&#xff0c;那么首先要过的坎就是国考。修满学分和通过校考一般都不会很难&#xff0c;只要按时上课、根据院校安排的课程复习即可。而国考是全国统一命题、考试&#xff0c;大部分专业要考2门&#xff0c;对于有的同学来说&#xff0c;备考压…

从零开始学Python第13课:常用数据结构之字典

迄今为止&#xff0c;我们已经为大家介绍了Python中的三种容器型数据类型&#xff0c;但是这些数据类型仍然不足以帮助我们解决所有的问题。例如&#xff0c;我们需要一个变量来保存一个人的信息&#xff0c;其中包含了这个人的姓名、年龄、身高、体重、家庭住址、本人手机号、…

Springboot 自定义缓存配置 CacheManager 及redis集成

目录 前言 集成 maven依赖 CacheManagerConfig配置 redis配置 使用 Springboot 集成使用缓存 Cacheable CacheEvict 前言 现有项目中经常遇到的缓存集成问题&#xff0c;Springboot提供了统一的接口抽象与缓存管理器&#xff0c;可集成多种缓存类型&#xff0c;如 Co…

Java阶段二Day10

Java阶段二Day10 文章目录 Java阶段二Day10DQLGROUP BY 分组按单字段分组例 按多字段分组例 按照聚合函数的结果排序例 HAVING子句问题错误原因HAVING子句的应用HAVING和WHERE的区别例 子查询 (SubQuery)概念应用场景子查询分类在DQL中使用子查询单行单列子查询例 多行单列子查…

hook函数

什么是hook函数 在计算机编程中&#xff0c;hook函数是指在特定的事件发生时被调用的函数&#xff0c;用于在事件发生前或后进行一些特定的操作。通常&#xff0c;hook函数作为回调函数被注册到事件处理器中&#xff0c;当事件发生时&#xff0c;事件处理器会自动调用相应的ho…

QtDAY 2

代码&#xff1a; 头文件&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QDebug> #include <QString> #include <QTextToSpeech>QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACEclass Widget : …

【Hello Network】网络编程套接字(二)

作者&#xff1a;小萌新 专栏&#xff1a;网络 作者简介&#xff1a;大二学生 希望能和大家一起进步 本篇博客简介&#xff1a;简单介绍网络的基础概念 网络编程套接字&#xff08;二&#xff09; 简单的TCP网络程序服务端创建套接字服务端绑定服务器监听服务端获取连接服务端处…

Qt Quick Qml-Rectangle案例

Qt Quick - Qml 1.Rectangle //组件 IShadow.qml import QtQuick import QtQuick.ControlsItem {id:rootanchors.fill: parentanchors.margins: -4property color color: "#999999"property int radius: 4Rectangle{width: root.widthheight: root.heightanchors.ce…

原型图都可以用什么软件做?分享这9款给你

设计师在进行原型设计师时&#xff0c;会使用原型图软件&#xff0c;从产生想法到向开发人员提交项目。无论是构建基本线框还是功能齐全的原型&#xff0c;原型图软件都可以为你节省大量的时间和精力。 如果你是这个领域的新手或者想更新你的原型图软件包&#xff0c;请快速看…

iOS App的生命周期

App的生命周期 App从启动到退出的过程中&#xff0c;iOS应用程序不断从系统接收各种事件&#xff0c;如&#xff1a;用户点击了屏幕、用户点击了Home键&#xff0c;并对这些事件进行响应。接受事件是UIApplication对象的工作&#xff0c;但是&#xff0c;响应事件就需要由程序…

Dubbo详解

一、基础知识 1、 RPC RPC【Remote Procedure Call】是指远程过程调用&#xff0c;是一种进程间通信方式&#xff0c;他是一种技术的思想&#xff0c;而不是规范。它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程或函数&#xff0c; 而不用程序员显式编码…

【unity细节】—(Can‘t add script)脚本文件无法拖拽到对象的问题

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 秩沅 原创 收录于专栏&#xff1a;unity细节和bug ⭐关于脚本文件无法拖拽到对象的问题⭐ 文章目录 ⭐关于脚本文件无法拖拽到对象的…

分治算法(Divide and Conquer)

本文已收录于专栏 《算法合集》 一、简单释义 1、分治算法 字面上的解释是“分而治之”&#xff0c;就是把一个复杂的问题拆分成两个或更多的相同或相似的子问题&#xff0c;再把子问题分成更小的子问题……直到最后子问题可以简单的直接求解&#xff0c;原问题的解即子问题的…

什么是FAQ页面?如何设计一个优秀的FAQ页面?

随着互联网技术的迅猛发展&#xff0c;越来越多的企业开始将在线客户支持服务作为一种重要的业务方式&#xff0c;以提供更好的服务体验。然而&#xff0c;在线客户支持服务除了提供实时的沟通方式外&#xff0c;一个功能齐全、易于使用的FAQ页面也是必不可少的&#xff0c;这可…

Go 语言进阶与依赖管理

作者&#xff1a;非妃是公主 专栏&#xff1a;《Golang》 博客主页&#xff1a;https://blog.csdn.net/myf_666 个性签&#xff1a;顺境不惰&#xff0c;逆境不馁&#xff0c;以心制境&#xff0c;万事可成。——曾国藩 文章目录 一、语言进阶1. 并发和并行2. 协程(Goroutine…

软件or硬件?硬件的前途到底在哪里?

一、硬件明明比软件更难&#xff0c;国内的硬件技术也不如软件&#xff0c;为什么硬件工程师待遇还不如软件&#xff1f; 1、不需要太高层次的硬件设计&#xff0c;比如大部分小家电企业&#xff0c;简单的电子产品企业&#xff0c;单片机简单外围设计就够了&#xff0c;单片机…