Java的反射机制
前言:
JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为java语言的反射机制。
Java反射的使用:
有如下student类:
public class Student { private int age; private String name; public Student() { super(); } public Student(int age, String name) { super(); this.age = age; this.name = name; } public void study() { System.out.println("测试反射!"); } }
现在通过反射来获取student类的信息:
一、获取class对象
获取class对象有三种方式,如下:
1、方式一:
Class clazz =Class.forName("com.demos.reflect.Student");
注意:forName里面的参数是Student的全类名。
2、方式二:
Class clazz = Student.class;
3、方式三:
Class clazz = stu.getClass();
注:这种方法是已有该类的对象时使用,即已有stu对象。
二、获取类的信息
得到了Class对象后,就可以通过Class对象获取类的信息,部分方法如下:
1、获取属性:
Field[] fs = clazz.getDeclaredFields();//获取所有属性 for(Field f : fs) { //获取属性名 System.out.println(f.getName()); //获取属性的数据类型 Class pp = f.getType(); System.out.println(pp.getName());//类型带包名 //System.out.println(pp.getSimpleName());//不带包名 }
2、获取类的方法:
//拿单个方法(study方法有参数的话还得写上参数类型, //例如:clazz.getMethod("study",String.Class)) //Method m = clazz.getMethod("study");//获取单个方法 //Method[] ms = clazz.getMethods();//包括父类方法 Method[] ms = clazz.getDeclaredMethods();//不包括父类方法 for(Method m : ms) { //获取类的方法名 System.out.println(m.getName()); }
三、动态创建对象,调用方法
1.1、创建对象方式一:
Object obj = clazz.newInstance(); System.out.println(obj);
注意:这种方式创建对象因为没传参数,所以Student类必须要有一个无参构造。
1.2、创建对象方式二:
Constructor cos = clazz.getConstructor(int.class,String.class); Object obj2 = (Student)cos.newInstance(20,"张三"); System.out.println(obj2);
注意:这种方式带参创建对象,需要有带参构造。
2、调用方法:
有了对象就可以调该类的方法,如下:
Method m = clazz.getMethod("study"); m.invoke(obj);
控制台输出输出"测试反射",正是study方法里打印的那句话。
总结:
Java的反射机制应用非常广泛,像spring、hibernate等框架底层都用到了反射,理解反射机制,可以帮助我们更好的理解这些框架的原理。
以上内容属于个人笔记整理,如有错误,欢迎批评指正!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
SpringBoot 整合 oauth2(五)实现 jwt 及 扩展
什么是jwt,即 json web token。JWT是一种用于双方之间传递安全信息的简洁的、URL安全的表述性声明规范。也是一种token,但是和token有一些不同。 jwt优点: 自包含 防篡改 可自定义扩展 JWT的结构 JWT包含了使用.分割的三部分: Header 头部 Payload 负载 Signature 签名 比如:eyJpc3MiOiJKb2huIFd1IEpXVCIsImlhdCI6MTQ0MTU5MzUwMiwiZXhwIjoxNDQxNTk0NzIyLCJhdWQiOiJ3d3cuZXhhbXBsZS5jb20iLCJzdWIiOiJqcm9ja2V0QGV4YW1wbGUuY29tIiwiZnJvbV91c2VyIjoiQiIsInRhcmdldF91c2VyIjoiQSJ9 三个新东西 什么是自包含? 字符串里包含用户信息。 什么是防篡改? 签名用于验证消息的发送者以及消息是没有经过篡改的。 可扩展是什么意思? 你可以在Payload部分加入自己想加入的json字符串 那我们既然token的实现方式那么优秀,为什么还要有jwt呢,这就需要了解他们的生成机...
- 下一篇
leetcode算法题解(Java版)-16-动态规划(单词包含问题)
一、递归 题目描述 Given two binary trees, write a function to check if they are equal or not. Two binary trees are considered equal if they are structurally identical and the nodes have the same value. 思路 碰到二叉树的问题,差不多就是深搜、广搜,递归那方面想想了,当然如果要考虑一下空间、时间,还需要进行剪枝和压缩处理。这题比较简单:判断两个树是否相等,可以递归的判断子树是否相等,最后找到边界条件就是是否都为空,都不为空时节点里面的值是否相等。 代码 /** * Definition for binary tree * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */ public class Solution { public boole...
相关文章
文章评论
共有0条评论来说两句吧...