浅谈Java反射机制 之 获取类的 方法 和 属性(包括构造函数)
上一篇 获取 类 的字节码文件 我们讲到了获取类的字节码文件的三种方法
第三种方法通过getClass("全路径名")获取字节码文件最符合要求
1、获取构造方法
先贴上我们要获取的类结构
import java.util.Date;
public class Student {
private String name;
private Integer age;
private Date Birthday;
public Student(){
}
private Student(String name){
this.name=name;
}
private Student(Integer age){
this.age=age;
}
private Student(Date Birthday){
this.Birthday=Birthday;
}
public Student(String name,Integer age){
this.name=name;
this.age=age;
}
public Student(Integer age,String name){
this.name=name;
this.age=age;
}
public Student(String name,Date Birthday){
this.name=name;
this.Birthday=Birthday;
}
public Student(Date Birthday,String name){
this.name=name;
this.Birthday=Birthday;
}
public Student(Integer age,Date Birthday){
this.age=age;
this.Birthday=Birthday;
}
public Student(Date Birthday,Integer age){
this.age=age;
this.Birthday=Birthday;
}
public Student(String name,Integer age,Date Birthday){
this.age=age;
this.name=name;
this.Birthday=Birthday;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public Date getBirthday() {
return Birthday;
}
public void setSex(Date sex) {
this.Birthday = Birthday;
}
}
通过 getConstructors() getDeclaredConstructors() getConstructor() getDeclaredConstructor()这四个方法获取各种构造方法
import java.lang.reflect.Constructor;
import java.util.Date; public class Test04 {
public static void main(String[] args) throws ClassNotFoundException,NoSuchMethodException{ //加载Class对象
//会报出不存在该类的异常
Class c=Class.forName("com.reflection.model.Student"); //获取所有公用构造方法
System.out.println("================获取所有公共的构造方法=================");
Constructor[] constructors=c.getConstructors();
for (Constructor constructor:constructors) {
System.out.println("公共的构造方法:"+constructor);
}
//获取所有构造方法
System.out.println("================获取所有的构造方法=================");
Constructor[] declaredconstructors=c.getDeclaredConstructors();
for (Constructor constructor:declaredconstructors) {
System.out.println("所有构造方法:"+constructor);
} //获取公有&无参构造方法
System.out.println("================获取公有&无参构造方法================="); //会报出没有该方法的异常
Constructor constructor1=c.getConstructor(null);
System.out.println("公有&无参构造方法:"+constructor1); //获取公有&有参构造方法
System.out.println("================获取公有&有参构造方法================="); //会报出没有该方法的异常
Constructor constructor2=c.getConstructor(new Class[]{String.class,Integer.class, Date.class});
System.out.println("公有&有参构造方法:"+constructor2);
Constructor constructor3=c.getConstructor(new Class[]{String.class,Integer.class});
System.out.println("公有&有参构造方法:"+constructor3); //获取私有&有参构造方法
System.out.println("================获取私有&有参构造方法================="); //会报出没有该方法的异常
Constructor declaredconstructor1=c.getDeclaredConstructor(new Class[]{String.class});
System.out.println("私有&有参构造方法:"+declaredconstructor1);
}
}
结果:
================获取所有公共的构造方法=================
公共的构造方法:public com.reflection.model.Student(java.lang.Integer,java.lang.String)
公共的构造方法:public com.reflection.model.Student(java.lang.String,java.util.Date)
公共的构造方法:public com.reflection.model.Student(java.util.Date,java.lang.String)
公共的构造方法:public com.reflection.model.Student(java.lang.Integer,java.util.Date)
公共的构造方法:public com.reflection.model.Student(java.util.Date,java.lang.Integer)
公共的构造方法:public com.reflection.model.Student(java.lang.String,java.lang.Integer,java.util.Date)
公共的构造方法:public com.reflection.model.Student()
公共的构造方法:public com.reflection.model.Student(java.lang.String,java.lang.Integer)
================获取所有的构造方法=================
所有构造方法:public com.reflection.model.Student(java.lang.Integer,java.lang.String)
所有构造方法:public com.reflection.model.Student(java.lang.String,java.util.Date)
所有构造方法:public com.reflection.model.Student(java.util.Date,java.lang.String)
所有构造方法:public com.reflection.model.Student(java.lang.Integer,java.util.Date)
所有构造方法:public com.reflection.model.Student(java.util.Date,java.lang.Integer)
所有构造方法:public com.reflection.model.Student(java.lang.String,java.lang.Integer,java.util.Date)
所有构造方法:public com.reflection.model.Student()
所有构造方法:private com.reflection.model.Student(java.lang.String)
所有构造方法:private com.reflection.model.Student(java.lang.Integer)
所有构造方法:private com.reflection.model.Student(java.util.Date)
所有构造方法:public com.reflection.model.Student(java.lang.String,java.lang.Integer)
================获取公有&无参构造方法=================
公有&无参构造方法:public com.reflection.model.Student()
================获取公有&有参构造方法=================
公有&有参构造方法:public com.reflection.model.Student(java.lang.String,java.lang.Integer,java.util.Date)
公有&有参构造方法:public com.reflection.model.Student(java.lang.String,java.lang.Integer)
================获取私有&有参构造方法=================
私有&有参构造方法:private com.reflection.model.Student(java.lang.String)
结论:
getConstructors()返回所有public的构造器。
getDeclaredConstructors()返回所有private和public构造器。
getConstructor()返回指定参数类型public的构造器。
getDeclaredConstructor()返回指定参数类型的private和public构造器。
2、获取类属性
将 1 中的 Student 类中的 name 字段设为 public
public String name;
通过 getFields() getDeclaredFields() getField() getDeclaredField()这四个方法获取各种字段
import java.lang.reflect.Field;
public class Test05 {
public static void main(String[] args) throws ClassNotFoundException, NoSuchFieldException { //加载Class对象
//会报出不存在该类的异常
Class c=Class.forName("com.reflection.model.Student"); //获取所有公用公共字段
System.out.println("================获取所有公共字段=================");
Field[] fields=c.getFields();
for (Field field:fields) {
System.out.println("公共字段:"+field);
}
//获取所有字段
System.out.println("================获取所有的字段(公共的、私有的)=================");
Field[] declaredFields=c.getDeclaredFields();
for (Field declaredfield:declaredFields) {
System.out.println("所有字段:"+declaredfield);
} System.out.println("================根据字段名获取公共字段=================");
//根据字段名获取公共字段
Field field1=c.getField("name");
System.out.println("根据字段名获取公共字段:"+field1); System.out.println("================根据字段名私有字段=================");
//根据字段名获取公共字段
Field field2=c.getDeclaredField("age");
System.out.println("根据字段名获取公共字段:"+field2); }
}
结果:
================获取所有公共字段=================
公共字段:public java.lang.String com.reflection.model.Student.name
================获取所有的字段(公共的、私有的)=================
所有字段:public java.lang.String com.reflection.model.Student.name
所有字段:private java.lang.Integer com.reflection.model.Student.age
所有字段:private java.util.Date com.reflection.model.Student.Birthday
================根据字段名获取公共字段=================
根据字段名获取公共字段:public java.lang.String com.reflection.model.Student.name
================根据字段名私有字段=================
根据字段名获取公共字段:private java.lang.Integer com.reflection.model.Student.age
结论:
getFields()返回所有public的字段。
getDeclaredFields()返回所有private和public字段。
getField()返回指定字段名public的字段。
getDeclaredField()返回指定字段名的private和public字段名。
3、获取类中的方法
在 1 中的Student类中定义几个方法
public void method1(String str){
System.out.println("public 修饰的方法");
}
private void method2(){
System.out.println("private 修饰的方法");
}
String method3(String name,Integer sex,Date age){
System.out.println("默认修饰"+name+" "+sex+" "+age);
return name+" "+sex+" "+age;
}
protected void method4(){
System.out.println("protected 修饰的方法");
}
通过 getMethods() getDeclaredMethods() getMethod() getDeclaredMethod()这四个方法获取各种方法
import java.lang.reflect.Method;
import java.util.Date; public class Test06 {
public static void main(String[] args) throws ClassNotFoundException, NoSuchMethodException { //加载Class对象
//会报出不存在该类的异常
Class c=Class.forName("com.reflection.model.Student"); //获取所有公共方法
System.out.println("================获取所有公共方法=================");
Method[] methods=c.getMethods();
for (Method method:methods) {
System.out.println("公共方法:"+method);
}
//获取所有方法
System.out.println("================获取所有的方法=================");
Method[] declaredMethods=c.getDeclaredMethods();
for (Method declaredmethod:declaredMethods) {
System.out.println("所有方法:"+declaredmethod);
} System.out.println("================获取特定(带参)方法=================");
Method method1=c.getMethod("method1",String.class);
System.out.println("特定(带参)方法:"+method1); System.out.println("================获取特定(不带参)方法=================");
Method method2=c.getDeclaredMethod("method2");
System.out.println("特定(不带参)方法:"+method2); System.out.println("================获取特定(多参)方法=================");
Method method3=c.getDeclaredMethod("method3", String.class, Integer.class, Date.class);
System.out.println("特定(多参)方法:"+method3);
}
}
结果:
================获取所有公共方法=================
公共方法:public java.lang.String com.reflection.model.Student.getName()
公共方法:public void com.reflection.model.Student.setName(java.lang.String)
公共方法:public void com.reflection.model.Student.method1(java.lang.String)
公共方法:public void com.reflection.model.Student.setSex(java.util.Date)
公共方法:public java.util.Date com.reflection.model.Student.getBirthday()
公共方法:public java.lang.Integer com.reflection.model.Student.getAge()
公共方法:public void com.reflection.model.Student.setAge(java.lang.Integer)
公共方法:public final void java.lang.Object.wait() throws java.lang.InterruptedException
公共方法:public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException
公共方法:public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException
公共方法:public boolean java.lang.Object.equals(java.lang.Object)
公共方法:public java.lang.String java.lang.Object.toString()
公共方法:public native int java.lang.Object.hashCode()
公共方法:public final native java.lang.Class java.lang.Object.getClass()
公共方法:public final native void java.lang.Object.notify()
公共方法:public final native void java.lang.Object.notifyAll()
================获取所有的方法=================
所有方法:public java.lang.String com.reflection.model.Student.getName()
所有方法:public void com.reflection.model.Student.setName(java.lang.String)
所有方法:private void com.reflection.model.Student.method2()
所有方法:public void com.reflection.model.Student.method1(java.lang.String)
所有方法:java.lang.String com.reflection.model.Student.method3(java.lang.String,java.lang.Integer,java.util.Date)
所有方法:public void com.reflection.model.Student.setSex(java.util.Date)
所有方法:public java.util.Date com.reflection.model.Student.getBirthday()
所有方法:protected void com.reflection.model.Student.method4()
所有方法:public java.lang.Integer com.reflection.model.Student.getAge()
所有方法:public void com.reflection.model.Student.setAge(java.lang.Integer)
================获取特定(带参)方法=================
特定(带参)方法:public void com.reflection.model.Student.method1(java.lang.String)
================获取特定(不带参)方法=================
特定(不带参)方法:private void com.reflection.model.Student.method2()
================获取特定(多参)方法=================
特定(多参)方法:java.lang.String com.reflection.model.Student.method3(java.lang.String,java.lang.Integer,java.util.Date)
结论:
getMethods()返回所有public的方法,通过结果可以看出getMethods()连父类中的。public方法也可以获取到
getDeclaredMethods()返回所有private和public方法名,。getDeclaredMethods()获取不到父类中的方法,只能获取到本来中的方法
get返回指定字段名Method()public的方法名。
getDeclared返回指定字方法名的Method()private和public字段名。
注:
由getMethods()和getDeclaredMethods()方法我们推测获取字段的方法和获取构造函数的方法
应该和getMethods()和getDeclaredMethods()一样,
为了验证,又定义了一个People类,getFields()和getDeclaredFields()
public class People {
public String head;
public String foot;
}
Student继承People
================获取所有公共字段=================
公共字段:public java.lang.String com.reflection.model.Student.name
公共字段:public java.lang.String com.reflection.model.People.head
公共字段:public java.lang.String com.reflection.model.People.foot
================获取所有的字段(公共的、私有的)=================
所有字段:public java.lang.String com.reflection.model.Student.name
所有字段:private java.lang.Integer com.reflection.model.Student.age
所有字段:private java.util.Date com.reflection.model.Student.Birthday
getFields()可以获取到父类的所有公共的字段,getDeclaredFields()只能获取到本类中的字段
================获取所有公共的构造方法=================
公共的构造方法:public com.reflection.model.Student(java.lang.String,java.lang.String)
================获取所有的构造方法=================
所有构造方法:public com.reflection.model.Student(java.lang.String,java.lang.String)
上面的结果也证明了
获取到父类的构造方法,getConstructors()不能getDeclaredConstructors()也只能获取到本类中的构造方法
浅谈Java反射机制 之 获取类的 方法 和 属性(包括构造函数)的更多相关文章
- 浅谈Java反射机制 之 获取类的字节码文件 Class.forName("全路径名") 、getClass()、class
另一个篇:获取 类 的 方法 和 属性(包括构造函数) 先贴上Java反射机制的概念: AVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法: 对于任意一个对象,都能够调用它 ...
- Java反射机制 之 获取类的 方法 和 属性(包括构造函数)(Day_06)
把自己立成帆,才能招来凤. 运行环境 JDK8 + IntelliJ IDEA 2018.3 本文中使用的jar包链接 https://files.cnblogs.com/files/papercy ...
- 浅谈Java反射机制 之 使用类的 属性、方法和构造函数
前面两篇我们总结了Java反射机制如何获取类的字节码,如何获取构造函数,属性和方法, 这篇我们将进一步验证如何使用我们获取到的属性.方法以及构造函数 1.使用 反射 获取到的 属性 import ja ...
- 浅谈java反射机制
目录 什么是反射 初探 初始化 类 构造函数 属性 方法 总结 思考 什么是反射 JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意 ...
- 浅谈 java 反射机制
一:Java反射概念 Java反射是Java被视为动态(或准动态)语言的一个关键性质.这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息,包括其mod ...
- JAVA反射机制教程-获取类对象
1. 什么是类对象 类对象,就是用于描述这种类,都有什么属性,什么方法的 2. 获取类对象 获取类对象有3种方式(1). Class.forName(2). Hero.class(3). new He ...
- Java反射机制涉及的类常见方法使用总结
import java.lang.reflect.Constructor; import java.lang.reflect.*; /*Class:代表一个字节码文件的对象,每当有类被加载进内存,JV ...
- Java -- 浅入Java反射机制
1,Java 反射是Java语言的一个很重要的特征,它使得Java具体了"动态性". Java 反射机制主要提供了以下功能: 在运行时判断任意一个对象所属的类. 在运行时构造任意一 ...
- java 通过反射机制调用某个类的方法
package net.xsoftlab.baike; import java.lang.reflect.Method; public class TestReflect { public s ...
随机推荐
- XMPP实现原理
XMPP协议简介 XMPP(Extensible Messageing and Presence Protocol:可扩展消息与存在协议)是目前主流的四种IM(IM:instant messagi ...
- c++ Socket客户端和服务端示例版本一
客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...
- Linux--用户与用户组--03
用户管理: 1.useradd 创建用户 -c 指定用户描述 -d 指定家目录 -g 指定主组 -G 指定附加组 附加组可以有多个 -s 指定shell程序 特殊的/sbin/nologin--> ...
- windows下挂载NFS共享目录
1.在打开或关闭Windows功能中,选择安装NFS客户端 2.在命令行中,输入“mount \\172.24.184.31\data x:\”,输入mount查看详细挂载参数(注意此时uid.gid ...
- 基于tcp和udp协议的套接字
socket:是在应用层和传输层之间的一个抽象层,它把TCP/IP层的复杂的操作封装抽象,并提供一些接口供应用层调用 套接字:被设计用于同一台主机上多个应用程序之间的通信,被称为进程之间通信或IPC ...
- 北京师范大学第十五届ACM决赛-重现赛K Keep In Line ( 字符串模拟实现)
链接:https://ac.nowcoder.com/acm/contest/3/K 来源:牛客网 Keep In Line 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...
- 2019 计蒜之道 初赛 第一场 商汤AI园区的n个路口(中等) (树形dp)
北京市商汤科技开发有限公司建立了新的 AI 人工智能产业园,这个产业园区里有 nn 个路口,由 n - 1n−1 条道路连通.第 ii 条道路连接路口 u_iui 和 v_ivi. 每个路口都布有 ...
- solaris硬盘格式化分区
创建EFI分区及挂载文件系统的过程: # format AVAILABLE DISK SELECTIONS: 0. c1t0d0 <LSI-MR9261-8i-2.12-557.86GB> ...
- Vuex-全局状态管理【传递参数】
src根目录 新建store文件夹,新建index.js 作为入口 在store文件夹中 新建modules文件夹 modules文件夹中,新建 a.js b.js 2个文件 a.js const s ...
- Flink Batch SQL 1.10 实践
Flink作为流批统一的计算框架,在1.10中完成了大量batch相关的增强与改进.1.10可以说是第一个成熟的生产可用的Flink Batch SQL版本,它一扫之前Dataset的羸弱,从功能和性 ...