首先写一个类
public class MyObject {
public int a;
public int b;
public MyObject() {
}
private MyObject(int a) {
}
public MyObject(int a, int b) {
this.a = a;
this.b = b;
}
public int sum(){
return a+b;
}
public int minus(){
return a-b;
}
public int multiply(){
return a*b;
}
public int divide(){
return a/b;
}
public void voidGet(){
}
public int divide(int c,int d){
return c/d;
}
}
测试如下
//获取类
System.out.println("--------获取类-------------------------");
Class cls=Class.forName("reflect.MyObject");
System.out.println(cls);
System.out.println(MyObject.class);
System.out.println(cls.getClass());
//测试获取类的方法
Method []method=cls.getDeclaredMethods();
for(int i=0;i<method.length;i++){
Method m=method[i];
Class pclass[]=m.getParameterTypes();
System.out.println("参数个数:"+pclass.length);
for(int j=0;j<pclass.length;j++){
System.out.println("参数:"+pclass[j].toString());
}
System.out.println("方法名:"+m.getName());
System.out.println("修饰符:"+m.getModifiers());
System.out.println("返回值:"+m.getReturnType());
}
//取得类的构造函数
System.out.println("--------取得类的构造函数-------------------------");
Constructor cor[]=cls.getDeclaredConstructors();
for(int i=0;i<cor.length;i++){
Constructor co=cor[i];
System.out.println("方法名:"+co.getName());
System.out.println("修饰符:"+co.getModifiers());
//参数列表
Class params[]=co.getParameterTypes();
for(int j=0;j<params.length;j++){
System.out.println("参数:"+params[j].toString());
}
}
//测试获取字段
System.out.println("--------测试获取字段-------------------------");
Field []field=cls.getDeclaredFields();
for(int i=0;i<field.length;i++){
Field m=field[i];
System.out.println("变量名:"+m.getName());
System.out.println("修饰符:"+m.getModifiers());
System.out.println("变量类型:"+m.getType());
}
//参数类型
Class ptype[]=new Class[2];
ptype[0]=int.class;
ptype[1]=int.class;
try {
Constructor corr=cls.getConstructor(ptype);
try {
Object obj=corr.newInstance(6,3);
//改变字段的值
try {
Field fielda=cls.getField("a");
System.out.println("改变前:a="+fielda.get(obj));
fielda.set(obj, 100);
System.out.println("改变后:a="+fielda.get(obj));
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchFieldException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//执行方法
Method me=cls.getMethod("sum");
Object returnvalue=me.invoke(obj);
System.out.println("加="+returnvalue);
me=cls.getMethod("minus");
returnvalue=me.invoke(obj);
System.out.println("减="+returnvalue);
me=cls.getMethod("multiply");
returnvalue=me.invoke(obj);
System.out.println("乘="+returnvalue);
me=cls.getMethod("divide");
returnvalue=me.invoke(obj);
System.out.println("除="+returnvalue);
me=cls.getMethod("voidGet");
returnvalue=me.invoke(obj);
System.out.println("无返回值="+returnvalue);
me=cls.getMethod("divide",new Class[]{int.class,int.class});
returnvalue=me.invoke(obj,new Integer[]{6,3});
System.out.println("有参数的私有="+returnvalue);
//数组
Class str=Class.forName("java.lang.String");
Object arr=Array.newInstance(str, 10);
Array.set(arr, 5, "this is a test ");
Array.set(arr, 0, "this is a test ");
String str5=(String)Array.get(arr, 5);
String str0=(String)Array.get(arr, 0);
//String str10=(String)Array.get(arr, 10);//数组越界
System.out.println("数组元素="+str5);
System.out.println("数组元素="+str0);
//System.out.println("数组元素="+str10);
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//调用默认构造函数
corr=cls.getConstructor();
try {
Object obj1=corr.newInstance();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
测试结果如下:
--------获取类-------------------------
class reflect.MyObject
class reflect.MyObject
class java.lang.Class
参数个数:0
方法名:sum
修饰符:1
返回值:int
参数个数:0
方法名:minus
修饰符:1
返回值:int
参数个数:0
方法名:voidGet
修饰符:1
返回值:void
参数个数:2
参数:int
参数:int
方法名:divide
修饰符:1
返回值:int
参数个数:0
方法名:divide
修饰符:1
返回值:int
参数个数:0
方法名:multiply
修饰符:1
返回值:int
--------取得类的构造函数-------------------------
方法名:reflect.MyObject
修饰符:1
方法名:reflect.MyObject
修饰符:1
参数:int
参数:int
方法名:reflect.MyObject
修饰符:2
参数:int
--------测试获取字段-------------------------
变量名:a
修饰符:1
变量类型:int
变量名:b
修饰符:1
变量类型:int
改变前:a=6
改变后:a=100
加=103
减=97
乘=300
除=33
无返回值=null
有参数的私有=2
数组元素=this is a test
数组元素=this is a test
分享到:
相关推荐
掌握Java反射机制对于开发者来说是非常有价值的,尤其是在开发框架、自动化测试等方面的应用。 #### 十、参考资料 - [Oracle官方文档](https://docs.oracle.com/javase/tutorial/reflect/) - [Effective Java]...
### Java反射机制详解 #### 一、Java反射机制概述 Java反射机制是Java语言的一个重要特性,它允许程序在运行时获取类的信息并操作对象。Java反射机制的主要作用包括:获取类的所有属性和方法、构造动态实例、调用...
Java反射机制是Java编程语言中的一个重要特性,它允许程序在运行时获取和操作任何已知名称的类的内部信息。这一机制使得Java具备了一定的动态性,虽然在传统的分类中Java被视为静态类型语言。通过反射,开发者可以在...
Java 反射机制是 Java 语言中的一个重要特性,它允许程序在运行时动态地获取类的信息(如类名、属性、方法等)并调用对象的方法,甚至修改对象的状态。这一机制极大地增强了 Java 程序的灵活性和可扩展性,尤其是在...
Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查和操作类、接口、对象等的内部信息。通过Java反射机制,开发者可以在不知道具体类名的情况下创建对象,调用方法,访问和修改私有成员变量,以及...
本篇文章将深入探讨Java反射机制,并通过自定义框架的测试代码来进一步理解其应用。 首先,我们需要了解什么是反射。在Java中,反射是指在运行时,程序可以获取类、接口、字段和方法的信息,并且能够调用这些方法,...
### 反射实例—JAVA反射机制 #### 一、反射概念及原理 反射在计算机科学领域,特别是程序设计中,是指程序有能力访问、检测和修改其自身的结构和行为。这一概念最早由Smith于1982年提出,并迅速应用于各种编程语言...
这篇博文"Java反射机制学习(二)"可能深入探讨了如何利用反射进行动态类型处理、访问私有成员以及创建对象等核心概念。在这里,我们将详细讨论Java反射的基本用法及其在实际开发中的应用。 1. **什么是反射**: ...
### Java反射机制详解 #### 一、反射的基本概念与历史背景 反射的概念最早由Smith在1982年提出,其核心思想是程序有能力访问、检测甚至修改自身的状态和行为。这种能力一经提出,迅速成为了计算机科学领域的研究...
### Java反射机制详解 #### 一、什么是Java反射机制? Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的...
Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查和操作类、接口、对象等的内部结构。通过反射,开发者可以动态地获取类的信息并调用其方法,创建对象,访问私有成员,甚至改变类的行为。在深入...
Java反射机制是Java编程语言中的一个强大工具,它允许程序在运行时检查并操作类、接口、字段和方法等对象。在"北大青鸟java反射机制"的学习资料中,我们将会深入探讨这一核心特性。 首先,我们要理解反射的核心概念...
Java反射机制是Java编程语言中的一个强大特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。这个特性使得Java具有了高度的灵活性和动态性,尤其是在处理元数据、创建对象、调用私有方法...
### Java反射机制详解 #### 一、什么是Java的反射机制 Java反射机制是Java语言的一种重要特性,使得Java成为了一种动态性很强的语言。通过反射,可以在程序运行时获取类的信息,包括类名、父类、接口、字段、方法...
Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查和操作类、接口、字段以及方法等对象。这一机制的核心在于`java.lang.Class`类和相关的API,它们提供了对类元数据的访问,使得我们能够在运行时...
Java反射机制是Java语言提供的一种强大功能,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心类是java.lang.Class,它代表了运行时的类信息。通过Class对象,我们...
Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查并操作类、接口、字段和方法的信息,打破了通常编译时静态绑定的限制。通过反射,我们可以动态地创建对象,调用方法,访问和修改字段值,甚至...
Java反射机制是Java编程语言中一个强大的特性,它允许程序在运行时动态地访问、检测和修改类、接口、字段和方法等对象。然而,反射操作通常会引入额外的开销,这在性能敏感的应用场景下可能成为一个瓶颈。本文将深入...
Java反射机制是Java语言提供的一种强大工具,它允许在程序运行时动态地获取类的信息以及对类的对象进行操作。在Java中,静态编译时类型检查确保了代码的稳定性,但有时我们需要在运行时根据需求动态地创建对象、调用...