package com.jvm.seventh; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.lang.reflect.Modifier; public class TestReflect { public static void main(String[] args) throws Exception { //根据对象获取类名加包名 Demo demo=new Demo(); System.out.println(demo.getClass().getName()); //获取class的三种途径 Class clazz1=null; Class clazz2=null; Class clazz3=null; clazz1=demo.getClass(); clazz2=Demo.class; clazz3=Class.forName("com.jvm.seventh.Demo"); System.out.println(clazz1+","+clazz2+","+clazz3); //获取该类对象的接口 System.out.println("----------implements interface----------------"); Class[] inters=clazz1.getInterfaces(); for(int i=0;i<inters.length;i++){ System.out.println(inters[i].getName()); } //获取该类的父类 System.out.println("----------super class----------------"); Class superClass=clazz1.getSuperclass(); System.out.println(superClass.getName()); //获取对象 Demo d1=null; d1=(Demo)clazz1.newInstance(); d1.setAge(10); d1.setName("d1--name"); System.out.println(d1.toString()); //获取构造器 构造对象 //构造器的数组的参数索引根据实际类中构造器的顺序来寻找的 System.out.println("----------cosntructors ----------------"); Constructor[] cons=clazz1.getConstructors(); Demo d2=null; Demo d3=null; for(int i=0;i<cons.length;i++){ System.out.println(cons[i]); } d2=(Demo)cons[0].newInstance("d3--name",100); d3=(Demo)cons[1].newInstance(); System.out.println("d2:"+d2.toString()); System.out.println("d3:"+d3.toString()); //获取该类的属性 //self-class fields System.out.println("----------declared fields----------------"); Field[] fields=clazz1.getDeclaredFields(); for(int i=0;i<fields.length;i++){ int mod=fields[i].getModifiers(); String priv=Modifier.toString(mod); Class type=fields[i].getType(); System.out.println(priv+" "+type.getName()+" "+fields[i].getName()); } //super fileds System.out.println("----------super fields----------------"); Field[] superFields=clazz1.getFields(); for(int i=0;i<superFields.length;i++){ int mod=superFields[i].getModifiers(); String priv=Modifier.toString(mod); Class type=fields[i].getType(); System.out.println(priv+" "+type.getName()+" "+superFields[i].getName()); } //操作属性 System.out.println("----------oper name fields----------------"); Field name=clazz1.getDeclaredField("name"); name.setAccessible(true); name.set(demo, "asia"); System.out.println(name.get(demo)); //获取对象的方法 System.out.println("----------invoke methods----------------"); Method method=clazz1.getMethod("print",String.class); method.invoke(demo,"myArg"); } } interface int1{ public static final String int1="int1"; } interface int2{ public static final String int2="int2"; } class Demo implements int1,int2{ public Demo() { // TODO Auto-generated constructor stub } public Demo(String name,int age){ this.name=name; this.age=age; } private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { // TODO Auto-generated method stub return "[name="+name+",age="+age+"]"; } public void print(String arg){ System.out.println("[arg="+arg+",name="+name+",age="+age+"]"); } public void print(){ System.out.println("[name="+name+",age="+age+"]"); } }
相关推荐
在Java中,反射主要涉及到`java.lang.Class`类、`java.lang.reflect`包中的`Constructor`、`Method`和`Field`等类。通过反射,我们可以动态地获取类的信息(如类名、属性、方法),甚至可以在运行时创建和调用类的...
### Java反射机制详解 #### 一、引言 在Java编程语言中,反射(Reflection)是一种强大的工具,它允许程序在运行时访问类的信息并操纵类的对象。这种能力为Java程序提供了灵活性,使得代码能够在不知道具体类型的...
JAVA REFLECT (java 反射) 取得类的继承结构 - 类所在的包; |- public Package getPackage() - 类的声明方式; |-取得全类名:public String getName() |-只取类名: public String getSimpleName() - 类所继承...
免费共享,很详细的介绍了反射机制的原理,适合追根究底的java学习者
Java反射(Reflect)是Java语言的一个重要特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。`java reflect utils`通常是指一些工具类或库,用于简化和增强Java反射机制的使用。在Java...
Java反射机制是Java编程语言中的一个重要特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在本教程中,我们将深入...请参考`java_base10_reflect.ppt`来深入学习这一强大而复杂的主题。
Java反射是Java编程语言中的一个强大特性,它允许在运行时检查类、接口、字段和方法的信息,并且能够在运行时动态地创建对象和调用方法。这个特性使得Java具有高度的灵活性和动态性,但同时也增加了程序的复杂性和...
主要由java.lang.reflect.Proxy和java.lang.reflect.InvocationHandler接口组成。 1. **Proxy类**:Proxy类的newProxyInstance()方法用于创建动态代理对象,它需要一个ClassLoader、一个接口数组和一个...
要使用反射,你需要导入`java.lang.reflect`包中的类,如`Class`、`Constructor`、`Method`和`Field`。这些类分别代表类的元数据、构造器、方法和字段。通过`Class`的`forName()`方法,你可以根据类名获取到对应的`...
4. 动态代理:Java的`java.lang.reflect.Proxy`类可以生成动态代理类,实现接口的动态方法调用。 总的来说,Java反射为开发者提供了一种强大的工具,使我们能够在运行时探索和操纵类的结构和行为,极大地扩展了Java...
Java反射的使用 这个小例子简单介绍了Java使用反射的各种方法,帮助大家快速掌握Java反射的基本使用方法。例子程序是用Android Studio编写的,如果你使用Eclipse,新建一个工程,拷贝src下面的几个类过去就可以了....
首先,Java中的动态代理是通过`java.lang.reflect.Proxy`类和`java.lang.reflect.InvocationHandler`接口来实现的。`Proxy`类用于创建一个代理对象,而`InvocationHandler`接口则定义了处理代理对象的方法调用的逻辑...
JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。...
Java反射和动态代理是Java编程中的重要特性,它们在实现高度灵活...在提供的压缩包文件"JavaReflect"中,可能包含了关于Java反射和动态代理的示例代码和教程,通过学习和实践这些内容,你可以更深入地掌握这两种技术。
This is a tool library for Kotlin to use java reflect APIs in Kotlin simply method.It can modify or read the top level private visible property value in Kotlin way. Note: This tools only availible ...
Java中的反射(Reflect)是Java语言的一个重要特性,它允许运行时访问类的信息,包括类名、属性、方法等,并可以动态地创建对象和调用方法。反射在很多场景下非常有用,比如在框架开发、插件系统、元数据驱动编程等...
标题中的问题“scrcpy投屏 AssertionError: java.lang.reflect.InvocationTargetException”是用户在尝试使用Scrcpy时遇到的一个常见错误。这个错误通常意味着在执行某个方法时,Java运行时环境遇到了未预期的情况。...