Java 反射机制
简介
JAVA反射机制是在运行状态中,对于任意一个实体类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为java语言的反射机制。(摘自百度百科)
参考文章:深入理解Java反射
代码示例
利用反射机制打印任意一个类
ReflectTest.java
package main; import java.lang.reflect.*; import javax.swing.text.html.CSS; public class ReflectTest { private Class thisClass; public ReflectTest(Class thisClass) { this.thisClass = thisClass; } /** * 获取类名 * @return */ private String getName() { String className = thisClass.getName(); return className; } /** * 获取所有变量 * @return */ private String getAllField() { StringBuilder result = new StringBuilder(); // 获取所有变量 Field[] fields = thisClass.getDeclaredFields(); // 获取公有属性变量的方法: // fields = clazz.getFields(); // 循环遍历每个变量 for (Field field : fields) { // 获取变量类型(Class对象),并getName()转为字符串 String fieldType = field.getType().getName(); // 获取变量名称 String fieldName = field.getName(); // 获取变量修饰符 int modifierCode = field.getModifiers(); String accessType = Modifier.toString(modifierCode); result.append(" " + accessType + " " + fieldType + " " + fieldName + ";\n\n"); } return result.toString(); } /** * 获取所有方法 * @return */ private String getAllMethod() { StringBuilder result = new StringBuilder(); // 获取所有方法 Method[] methods = thisClass.getDeclaredMethods(); // 获取公有属性方法的方法: // methods = clazz.getMethods(); // 循环遍历每个方法 for (Method method : methods) { // 获取方法返回类型(Class对象),并getName()转为字符串 String methodType = method.getReturnType().getName(); // 获取方法名称 String methodName = method.getName(); // 获取方法修饰符 int modifierCode = method.getModifiers(); String accessType = Modifier.toString(modifierCode); // 获取方法的所有参数 Parameter parameters[] = method.getParameters(); result.append(" " + accessType + " " + methodType + " " + methodName + "("); // 循环遍历该方法的所有参数 for (int i = 0; i < parameters.length; i++) { Parameter parameter = parameters[i]; // 获取参数类型,并转为字符串 String paramType = parameter.getType().toString(); // 获取参数名称 String paramName = parameter.getName(); result.append(paramType + " " + paramName); if (i != parameters.length - 1) { result.append(", "); } } result.append(")\n\n"); } return result.toString(); } /** * 获取所有构造方法 * @return */ public String getAllConstructors() { StringBuilder result = new StringBuilder(); // 获取所有构造方法 Constructor[] constructors = thisClass.getDeclaredConstructors(); // 获取公有属性构造方法的方法 // constructors = clazz.getConstructors(); // 循环遍历每个构造方法 for (Constructor constructor : constructors) { // 获取构造方法的名称 String constructorName = constructor.getName(); // 获取构造方法的修饰符 int modifierCode = constructor.getModifiers(); String accessType = Modifier.toString(modifierCode); // 获取构造方法的所有参数 Parameter[] parameters = constructor.getParameters(); result.append(" " + accessType + " " + constructorName + "("); //循环遍历每个参数 for (int i = 0; i < parameters.length; i++) { Parameter parameter = parameters[i]; // 获取参数类型,并转为字符串 String paramType = parameter.getType().getName(); // 获取参数名称 String paramName = parameter.getName(); result.append(paramType + " " + paramName); if (i != parameters.length - 1) { result.append(", "); } } result.append(")\n\n"); } return result.toString(); } @Override public String toString() { String result = new StringBuilder() .append(getName() + " {\n\n") .append(getAllField()) .append(getAllConstructors()) .append(getAllMethod() + "\n}") .toString(); return result; } public static void main(String args[]) { Student s1; s1 = new Student(); ReflectTest test = new ReflectTest(s1.getClass()); System.out.println(test.toString()); } } Student.java package main; public class Student { private int id; private String name; private String sex; public Student() { } public Student(int id, String name, String sex) { } public void setId(int id) { this.id = id; } public int getId() { return id; } public void setName(String name) { this.name = name; } public String getName() { return name; } public void setSex(String sex) { this.sex = sex; } public String getSex() { return sex; } }
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Python正则表达式初识(七)
继续分享Python正则表达式的基础知识,今天给大家分享的特殊字符是“\s”、“\S”,具体的教程如下。 1、“\s”代表的意思是匹配空格,匹配模式“加\s油”代表的是字符“加”和“油”之间有空格的意思,如下图所示。 可以看到原始字符串中“加”和“油”之间有空格,与匹配条件相符合,所以匹配成功。 2、为了加强理解,现在将原始字符串改为“加加油”,字符中间不为空格,保持匹配模式不变,如下图所示。 可以看到无任何输出,说明匹配不成功。 3、如果“加”和“油”之间有多个空格的话,则只需要在匹配模式中将“加\s油”改为“加\s+油”即可,如下图所示。 4、“\S”代表的意思与“\s”代表的意思刚刚相反,也就是说匹配的那个字符只要不是空格,都可以匹配。如下图所示,继续用第二步那个例子,只要将匹配模式中的“\s”改为“\S”,其他的保持不变,如下图所示。 可以看到此时就可以匹配成功。 5、而将原始字符串改为“加 油”,两个字符中间有个空格,匹配模式不变,如下图所示。 可以看到此时无任何输出,说明匹配不成功。 6、同样的,如果要匹配多个非空白字符的话,只需要将“\S”改为“\S+”即可,如下图所示。...
- 下一篇
一次线上Java应用内存泄漏分析实例
由于JVM的内存管理采用GC垃圾自动回收机制,这使得Java程序员在编程的时候确实可以从内存管理中释放出来,但这也引发了另外一个大问题,一旦Java应用出现内存泄漏的时候,常常让人措手不及,陷入无从下手的尴尬境地,我们总不能一句话重启吧(苦笑)。 内存问题可能是大多数Java程序员心中都曾有过的伤,因为太容易遇见了。 下面这篇文章是我去年写在个人微信公众号上的,今天早上回头再看心中不免有些嘘嘘感慨,于是决定重新整理把它发到简书上来,以下为正文: 前2天负责的一个线上系统在早上9点20分接到大量用户反馈系统很卡,页面无响应。我联系运维及时查看后台服务器,发现WAS(Websphere) server bin目录下生成了javacore 和heapdump,这个消息让我整个人都不好了,项目推广关键时期居然来这么一出,可谓多事之秋,搞事情啊! 好吧,既然程序运行时遇到了坑,那我们就先来找到这个坑,再把坑填好(围笑)。 简单介绍下,线上应用运行在power linux OS平台之上,web容器为IBM WebSphere ,JDK ibm j9vm 64 位。 首先开始通过ibm ha456....
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Hadoop3单机部署,实现最简伪集群
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果