浅谈Java反射机制 之 使用类的 属性、方法和构造函数
前面两篇我们总结了Java反射机制如何获取类的字节码,如何获取构造函数,属性和方法,
这篇我们将进一步验证如何使用我们获取到的属性、方法以及构造函数
1、使用 反射 获取到的 属性
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Date; public class Test08 {
public static void main(String[] args) throws ClassNotFoundException, NoSuchFieldException, NoSuchMethodException, IllegalAccessException, InvocationTargetException, InstantiationException { //加载Class对象
//会报出不存在该类的异常
Class c=Class.forName("com.reflection.model.Student");
//类名
System.out.println("类名:"+c.getSimpleName());
//类的包名
System.out.println("类的包名:"+c.getPackage()); System.out.println("================使用获取到的字段=================");
//根据字段名获取字段
Object object= c.getConstructor().newInstance(); //获取公共字段
Field field1=c.getField("name");
//设置字段值
field1.set(object,"Not_Copy");
System.out.println("-----------------"+field1.getName()+"-------------");
System.out.println("name字段的值:"+field1.get(object));
System.out.println("name字段类型:"+field1.getType());
System.out.println("name字段修饰符:"+field1.getModifiers()); //私有字段
Field field2=c.getDeclaredField("loginName");
//开启 private 权限的方问权限
field2.setAccessible(true);
//设置字段值
field2.set(object,"Login_Not_Copy");
System.out.println("-----------------"+field2.getName()+"-------------");
System.out.println("loginName字段的值:"+field2.get(object));
System.out.println("loginName字段类型:"+field2.getType());
System.out.println("loginName字段修饰符:"+field2.getModifiers()); //私有字段
Field field3=c.getDeclaredField("age");
//开启 protected 权限的方问权限
field3.setAccessible(true);
//设置字段值
field3.set(object,23);
System.out.println("-----------------"+field3.getName()+"-------------");
System.out.println("age字段的值:"+field3.get(object));
System.out.println("age字段类型:"+field3.getType());
System.out.println("age字段修饰符:"+field3.getModifiers()); Field field4=c.getDeclaredField("Birthday");//私有字段
//开启 默认 权限的方问权限
field4.setAccessible(true);
//设置字段值
field4.set(object,new Date());
System.out.println("-----------------"+field4.getName()+"-------------");
System.out.println("Birthday字段的值:"+field4.get(object));
System.out.println("Birthday字段类型:"+field4.getType());
System.out.println("Birthday字段修饰符:"+field4.getModifiers());
}
}
结果:
类名:Student
类的包名:package com.reflection.model
================使用获取到的字段=================
-----------------name-------------
name字段的值:Not_Copy
name字段类型:class java.lang.String
name字段修饰符:1
-----------------loginName-------------
loginName字段的值:Login_Not_Copy
loginName字段类型:class java.lang.String
loginName字段修饰符:2
-----------------age-------------
age字段的值:23
age字段类型:class java.lang.Integer
age字段修饰符:4
-----------------Birthday-------------
Birthday字段的值:Mon Jul 22 21:28:02 CST 2019
Birthday字段类型:class java.util.Date
Birthday字段修饰符:0
结论:由代码 反射获取到的属性的 private、private 和 默认权限 都需要使用 暴力反射 ( .setAccessible(true) )来开启范围权限,才能访问。
2、使用 反射 获取到的 方法
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Date; public class Test08 {
public static void main(String[] args) throws ClassNotFoundException, NoSuchFieldException, NoSuchMethodException, IllegalAccessException, InvocationTargetException, InstantiationException { //加载Class对象
//会报出不存在该类的异常
Class c=Class.forName("com.reflection.model.Student"); System.out.println("================使用获取到的方法================="); Method method1=c.getMethod("method1", String.class);
//执行方法
Object invoke1 =method1.invoke(object,"method1");
System.out.println("-----------------"+method1.getName()+"-------------");
System.out.println("method1方法的返回参数列表:"+method1.getParameterTypes());
System.out.println("method1字段修饰符:"+method1.getModifiers());
System.out.println("method1字段修饰符:"+method1.getReturnType());
System.out.println("方法的返回值:"+invoke1); Method method2=c.getDeclaredMethod("method2");
//开启private权限的方问权限
method2.setAccessible(true);
//执行方法
Object invoke2 =method2.invoke(object,null);
System.out.println("-----------------"+method2.getName()+"-------------");
System.out.println("method2方法的返回参数列表:"+method2.getParameterTypes());
System.out.println("method2字段修饰符:"+method2.getModifiers());
System.out.println("method2字段修饰符:"+method2.getReturnType());
System.out.println("方法的返回值:"+invoke2); Method method3=c.getDeclaredMethod("method3", String.class, Integer.class, Date.class);
//开启默认权限的方问权限
method3.setAccessible(true);
//执行方法
Object invoke3= method3.invoke(object,"No_Copy",23,new Date());
System.out.println("-----------------"+method3.getName()+"-------------");
System.out.println("method3方法的返回参数列表:"+method3.getParameterTypes());
System.out.println("method3字段修饰符:"+method3.getModifiers());
System.out.println("method3字段修饰符:"+method3.getReturnType());
System.out.println("方法的返回值:"+invoke3); Method method4=c.getDeclaredMethod("method4");
//开启 protected 权限的方问权限
method4.setAccessible(true);
//执行方法
Object invoke4= method4.invoke(object,null);
System.out.println("-----------------"+method4.getName()+"-------------");
System.out.println("method4方法的返回参数列表:"+method4.getParameterTypes());
System.out.println("method4字段修饰符:"+method4.getModifiers());
System.out.println("method4字段修饰符:"+method4.getReturnType());
System.out.println("方法的返回值:"+invoke4); }
}
结果:
================使用获取到的方法=================
public 修饰的方法:method1
-----------------method1-------------
method1方法的返回参数列表:[Ljava.lang.Class;@14ae5a5
method1字段修饰符:1
method1字段修饰符:class java.lang.String
方法的返回值:method1
private 修饰的方法:method2
-----------------method2-------------
method2方法的返回参数列表:[Ljava.lang.Class;@7f31245a
method2字段修饰符:2
method2字段修饰符:class java.lang.String
方法的返回值:method2
protected 修饰的方法 method3
name:No_Copy age:23 birthday:Mon Jul 22 21:28:02 CST 2019
-----------------method3-------------
method3方法的返回参数列表:[Ljava.lang.Class;@6d6f6e28
method3字段修饰符:0
method3字段修饰符:class java.lang.String
方法的返回值:No_Copy 23 Mon Jul 22 21:28:02 CST 2019
protected 修饰的方法:method4
-----------------method4-------------
method4方法的返回参数列表:[Ljava.lang.Class;@135fbaa4
method4字段修饰符:4
method4字段修饰符:class java.lang.String
方法的返回值:method4
结论:由代码 反射获取到方法 的 private、private 和 默认权限 都需要使用 暴力反射 ( .setAccessible(true) )来开启范围权限,才能访问。
2、使用 反射 获取到的 构造函数
import com.reflection.model.Student; import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Date; public class Test08 {
public static void main(String[] args) throws ClassNotFoundException, NoSuchFieldException, NoSuchMethodException, IllegalAccessException, InvocationTargetException, InstantiationException { //加载Class对象
//会报出不存在该类的异常
Class c=Class.forName("com.reflection.model.Student");
System.out.println(Student.class.getSuperclass().getName());
System.out.println("================使用获取到的构造方法=================");
//调用默认的构造方法
Object object1= c.getConstructor().newInstance();
//指定要调用构造方法的参数 参数:指定每个参数的类型
Constructor constructor = c.getConstructor(String.class,String.class,Integer.class,Date.class); //利用构造constructor创建新实例 并传参调用此构造函数
Student stu = (Student) constructor.newInstance("Not_Copy","not_copy",25,new Date()); System.out.println(stu);
}
}
结果:
================使用获取到的构造方法=================
Student{name='Not_Copy', loginName='not_copy', age=25, Birthday=Mon Jul 22 21:49:12 CST 2019}
贴上 使用的 Student 和 People类:
People类
public class People {
public String head;
public String foot;
}
Student类:
import java.util.Date;
public class Student extends People{
public String name;
private String loginName;
protected Integer age;
Date Birthday;
public Student(){
super();
}
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,String loginName){
this.name=name;
this.loginName=loginName;
}
public Student(String name,Integer age,Date Birthday){
this.age=age;
this.name=name;
this.Birthday=Birthday;
}
public Student(String name,String loginName,Integer age,Date Birthday){
this.name=name;
this.loginName=loginName;
this.age=age;
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;
}
public String method1(String str){
System.out.println("public 修饰的方法:"+str);
return str;
}
private String method2(){
System.out.println("private 修饰的方法:"+"method2");
return "method2";
}
String method3(String name,Integer age,Date birthday){
System.out.println("protected 修饰的方法 method3 \n name:"+name+" age:"+age+" birthday:"+birthday);
return name+" "+age+" "+birthday;
}
protected String method4(){
System.out.println("protected 修饰的方法:"+"method4");
return "method4";
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", loginName='" + loginName + '\'' +
", age=" + age +
", Birthday=" + Birthday +
'}';
}
}
浅谈Java反射机制 之 使用类的 属性、方法和构造函数的更多相关文章
- 浅谈Java反射机制 之 获取类的字节码文件 Class.forName("全路径名") 、getClass()、class
另一个篇:获取 类 的 方法 和 属性(包括构造函数) 先贴上Java反射机制的概念: AVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法: 对于任意一个对象,都能够调用它 ...
- 浅谈Java反射机制 之 获取类的 方法 和 属性(包括构造函数)
上一篇 获取 类 的字节码文件 我们讲到了获取类的字节码文件的三种方法 第三种方法通过getClass("全路径名")获取字节码文件最符合要求 1.获取构造方法 先贴上我们要获取的 ...
- 浅谈java反射机制
目录 什么是反射 初探 初始化 类 构造函数 属性 方法 总结 思考 什么是反射 JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意 ...
- 浅谈 java 反射机制
一:Java反射概念 Java反射是Java被视为动态(或准动态)语言的一个关键性质.这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息,包括其mod ...
- Java -- 浅入Java反射机制
1,Java 反射是Java语言的一个很重要的特征,它使得Java具体了"动态性". Java 反射机制主要提供了以下功能: 在运行时判断任意一个对象所属的类. 在运行时构造任意一 ...
- 利用Java反射机制对实体类的常用操作工具类ObjectUtil
代码: ObjectUtil类: import java.lang.reflect.Field; import java.math.BigDecimal; import java.text.Simpl ...
- 浅谈java发射机制
目录 什么是反射 初探 初始化 类 构造函数 属性 方法 总结 思考 什么是反射 JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意 ...
- 浅谈Java反射
什么是反射? JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方法的功能称为java语 ...
- 浅谈Java反射与框架
Java反射 1.示例 1.用户类 package com.lf.entity; import com.lf.annotation.SetProperty; import com.lf.annotat ...
随机推荐
- Date与String互相转换及日期的大小比较
private static final String PATTERN = "yyyy-MM-dd HH:mm:ss"; /** * String转Date * * @param ...
- Hibernate:基于HQL实现数据查询
HQL: hibernate query language(hibernate特有的查询语言) hql是基于对象的查询语言,其语法与sql类似,但是他和sql的区别在于sql是面向表和字段的查询,而 ...
- PAT Advanced 1046 Shortest Distance (20 分) (知识点:贪心算法)
The task is really simple: given N exits on a highway which forms a simple cycle, you are supposed t ...
- 2014百度之星初赛第二场hdu 4831 Scenic Popularity
Scenic Popularity Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- C#基础知识之VS的快捷键汇总
VS中默认的常用快捷键.可以根据自己的习惯,自己设置快捷方式,工具->选项->环境->键盘. 编辑相关的键盘快捷键 Ctrl + K,Ctrl + C = 注释选定行 Ctrl + ...
- POJ 3741 Raid (平面最近点对)
$ POJ~3741~Raid $ (平面最近点对) $ solution: $ 有两种点,现在求最近的平面点对.这是一道分治板子,但是当时还是想了很久,明明知道有最近平面点对,但还是觉得有点不对劲. ...
- Azure Messaging
上篇博文中我们介绍了Azure ServiceBus Messaging的消息事务机制: Azure Messaging-ServiceBus Messaging消息队列技术系列7-消息事务(2017 ...
- 7.docker私有registry
一.Docker Registry分类 Registry用于保存docker镜像,包括镜像的层次结构和元数据.都是基于https或者http工作的. 用户可自建Registry,也可使用官方的Dock ...
- Java 内存屏障
内存屏障(Memory Barrier,或有时叫做内存栅栏,Memory Fence)是一种CPU指令,用于控制特定条件下的重排序和内存可见性问题.Java编译器也会根据内存屏障的规则禁止重排序. 内 ...
- 使用vue技术应当使用的技术和兼容性选择
假如你的前端框架使用了vue,那你可以大胆地使用以下技术,并忽略其他js和css的兼容性问题,因为 关于vue的兼容性 官方给出了规定 Vue 不支持 IE8 及以下版本,因为 Vue 使用了 IE8 ...