java反射的初理解
反射
获取类的方法:
Class<?> aClass1 = Class.forName("TestDemo.refection.User");//通过类路径获取
Class<User> userClass = User.class;//通过类名获取
User user = new User();
Class<? extends User> aClass = user.getClass();//通过实例对象获取
无论通过哪种方式获取,获取几个都是一个Class的实例:
Class<?> aClass1 = Class.forName("TestDemo.refection.User");
Class<?> aClass2 = Class.forName("TestDemo.refection.User");
Class<User> userClass = User.class;
User user = new User();
Class<? extends User> aClass = user.getClass();
System.out.println(aClass1.hashCode());
System.out.println(aClass2.hashCode());
System.out.println(userClass.hashCode());
System.out.println(aClass.hashCode());
/*
结果:
1360875712
1360875712
1360875712
1360875712
可以看出它们的hashCode都是一样的
*/
通过反射获取相应的Class类后,获取相应的方法、属性、构造器
public class Test04 {
public static void main(String[] args) throws Exception {
Class<?> aClass = Class.forName("TestDemo.refection.User1");
System.out.println(aClass.getName());//获取全类名
System.out.println(aClass.getSimpleName());//获取简单的类名
System.out.println("=========================================");
Field[] fields = aClass.getFields();//获取公有的属性
for (Field field : fields) {
System.out.println("public:" +field);
}
fields = aClass.getDeclaredFields();//获取全部(包括公有和私有)的属性
for (Field field : fields) {
System.out.println("getDeclaredFields:" +field);
}
System.out.println("=========================================");
System.out.println("获取所有公有的方法,包括父类的:");
Method[] methods = aClass.getMethods();
for (Method method : methods) {
System.out.println(method);
}
System.out.println("获取自己所有的方法,包括私有的:");
methods = aClass.getDeclaredMethods();
for (Method method : methods) {
System.out.println(method);
}
System.out.println("获取指定的公有的方法(包括父类的方法):");
Method setName = aClass.getMethod("setName", String.class);
System.out.println(setName);
Method notify = aClass.getMethod("notify");
System.out.println(notify);
System.out.println("获取指定的全部的方法(包括父类的方法,包括私有的方法):");
Method test = aClass.getDeclaredMethod("test");
System.out.println(test);
System.out.println("=========================================");
System.out.println("获取全部公有(自身的)的构造器:");
Constructor<?>[] constructors = aClass.getConstructors();
for (Constructor<?> constructor : constructors) {
System.out.println(constructor);
}
System.out.println("获取全部(自身的,包括私有的)的构造器");
constructors = aClass.getDeclaredConstructors();
for (Constructor<?> constructor : constructors) {
System.out.println(constructor);
}
System.out.println("获取指定的构造器(不包括私有的):");
System.out.println(aClass.getConstructor());
System.out.println("获取指定的构造器(包括私有的):");
System.out.println(aClass.getDeclaredConstructor(String.class));
}
}
class Fater1{
public Fater1(){}
}
class User1 extends Fater1{
private String name;
private int id;
public int age;
public User1() {
}
private User1(String name) {
this.name = name;
}
public User1(String name, int id, int age) {
this.name = name;
this.id = id;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
private void test(){
System.out.println("私有方法");
}
@Override
public String toString() {
return "User1{" +
"name='" + name + '\'' +
", id=" + id +
", age=" + age +
'}';
}
}
/*
结果:
TestDemo.refection.User1
User1
=========================================
public:public int TestDemo.refection.User1.age
getDeclaredFields:private java.lang.String TestDemo.refection.User1.name
getDeclaredFields:private int TestDemo.refection.User1.id
getDeclaredFields:public int TestDemo.refection.User1.age
=========================================
获取所有公有的方法,包括父类的:
public java.lang.String TestDemo.refection.User1.toString()
public java.lang.String TestDemo.refection.User1.getName()
public int TestDemo.refection.User1.getId()
public void TestDemo.refection.User1.setName(java.lang.String)
public void TestDemo.refection.User1.setAge(int)
public int TestDemo.refection.User1.getAge()
public void TestDemo.refection.User1.setId(int)
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 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 TestDemo.refection.User1.toString()
public java.lang.String TestDemo.refection.User1.getName()
public int TestDemo.refection.User1.getId()
public void TestDemo.refection.User1.setName(java.lang.String)
private void TestDemo.refection.User1.test()
public void TestDemo.refection.User1.setAge(int)
public int TestDemo.refection.User1.getAge()
public void TestDemo.refection.User1.setId(int)
获取指定的公有的方法(包括父类的方法):
public void TestDemo.refection.User1.setName(java.lang.String)
public final native void java.lang.Object.notify()
获取指定的全部的方法(包括父类的方法,包括私有的方法):
private void TestDemo.refection.User1.test()
=========================================
获取全部公有(自身的)的构造器:
public TestDemo.refection.User1(java.lang.String,int,int)
public TestDemo.refection.User1()
获取全部(自身的,包括私有的)的构造器
public TestDemo.refection.User1(java.lang.String,int,int)
private TestDemo.refection.User1(java.lang.String)
public TestDemo.refection.User1()
获取指定的构造器(不包括私有的):
public TestDemo.refection.User1()
获取指定的构造器(包括私有的):
private TestDemo.refection.User1(java.lang.String)
*/
反射创建对象实例(Constructor)、方法(Method)、属性(Field):
public class Test05 {
public static void main(String[] args) throws Exception {
Class<?> aClass = Class.forName("TestDemo.refection.AAA");
System.out.println("创建一个对象的实例,使用的无参构造器:");
AAA aaa = (AAA)aClass.newInstance();//如果没有无参构造器就会报错
System.out.println(aaa);
System.out.println("创建一个对象的实例,使用的有参构造器:");
AAA aaa1 = (AAA)aClass.getConstructor(int.class, String.class).newInstance(1,"水三丫");
System.out.println(aaa1);
System.out.println("创建一个对象的实例,使用的私有有参构造器:");
Constructor<?> declaredConstructor = aClass.getDeclaredConstructor(int.class);
//需要关闭权限,才可以使用私有的构造器
declaredConstructor.setAccessible(true);
AAA aaa2 = (AAA)declaredConstructor.newInstance(1);
System.out.println(aaa2);
System.out.println("===============================================");
System.out.println("反射使用一个公有方法:");
AAA aaa4 = (AAA)aClass.newInstance();//如果没有无参构造器就会报错
aClass.getMethod("setName", String.class).invoke(aaa4,"水三丫");
System.out.println(aaa4);
System.out.println("反射使用一个公有方法:");
AAA aaa5 = (AAA)aClass.newInstance();//如果没有无参构造器就会报错
Method test = aClass.getDeclaredMethod("test");
test.setAccessible(true);
test.invoke(aaa5);
System.out.println("================================================");
System.out.println("反射获取一个公有属性:");
AAA aaa6 = (AAA)aClass.newInstance();//如果没有无参构造器就会报错
Field field = aClass.getField("name");
field.set(aaa6,"水三丫");
System.out.println(aaa6);
System.out.println("反射获取一个私有属性:");
Field field1 = aClass.getDeclaredField("id");
field1.setAccessible(true);//关闭权限
field1.set(aaa6,1);
System.out.println(aaa6);
}
}
class AAA{
private int id;
public String name;
public AAA() {
}
private AAA(int id) {
this.id = id;
}
public AAA(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
private void test(){
System.out.println("我是私有的方法");
}
@Override
public String toString() {
return "AAA{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
}
/*
结果:
创建一个对象的实例,使用的无参构造器:
AAA{id=0, name='null'}
创建一个对象的实例,使用的有参构造器:
AAA{id=1, name='水三丫'}
创建一个对象的实例,使用的私有有参构造器:
AAA{id=1, name='null'}
===============================================
反射使用一个公有方法:
AAA{id=0, name='水三丫'}
反射使用一个公有方法:
我是私有的方法
================================================
反射获取一个公有属性:
AAA{id=0, name='水三丫'}
反射获取一个私有属性:
AAA{id=1, name='水三丫'}
*/
反射获取泛型:
public class Test06 {
public static void main(String[] args) throws Exception {
Class<BB> bbClass = BB.class;
System.out.println("获取参数类型");
Method method = bbClass.getMethod("test01", Map.class, List.class);
//获取类型
Type[] genericParameterTypes = method.getGenericParameterTypes();
for (Type genericParameterType : genericParameterTypes) {
System.out.println(genericParameterType);
//获取单个真实的泛型
if(genericParameterType instanceof ParameterizedType){
Type[] actualTypeArguments = ((ParameterizedType) genericParameterType).getActualTypeArguments();
for (Type actualTypeArgument : actualTypeArguments) {
System.out.println(actualTypeArgument);
}
}
}
System.out.println("===========================================");
System.out.println("获取返回值类型");
Method test02 = bbClass.getDeclaredMethod("test02", List.class);
Type genericReturnType = test02.getGenericReturnType();
System.out.println(genericReturnType);
if(genericReturnType instanceof ParameterizedType){
Type[] actualTypeArguments = ((ParameterizedType) genericReturnType).getActualTypeArguments();
for (Type actualTypeArgument : actualTypeArguments) {
System.out.println(actualTypeArgument);
}
}
System.out.println("===========================================");
System.out.println("获取未定型的返回值类型");
Method test03 = bbClass.getDeclaredMethod("test03");
Type genericReturnType1 = test03.getGenericReturnType();
System.out.println(genericReturnType1);
}
}
class BB{
public void test01(Map<String,BB> map, List<BB> list){
System.out.println("test01");
}
public Map<String,BB> test02(List<BB> list){
System.out.println("test01");
return null;
}
public <T>T test03(){
return null;
}
}
/*
结果:
获取参数类型
java.util.Map<java.lang.String, TestDemo.refection.BB>
class java.lang.String
class TestDemo.refection.BB
java.util.List<TestDemo.refection.BB>
class TestDemo.refection.BB
===========================================
获取返回值类型
java.util.Map<java.lang.String, TestDemo.refection.BB>
class java.lang.String
class TestDemo.refection.BB
===========================================
获取未定型的返回值类型
T
*/
java反射的初理解的更多相关文章
- JAVA反射机制及理解
JAVA反射 往往当我们面对一项新的知识时,我们往往需要知道三个方面,它是什么,它能做什么,它比原有知识强在哪里,我们该怎么使用它.当你能够解决这些问题时,便意味着你已经对这项知识入门了. 首先: 反 ...
- Java反射的浅显理解
一.回顾反射相关的知识 1.在xml文件中使用反射的好处: 1)代码更加灵活,后期维护只需要修改配置文件即可 · 初学者一般习惯于在代码本身上直接修改,后期也可以修改配置文件达到相同的目的 · 修改配 ...
- 我对java反射机制的理解
我们平常怎么用一个使用类,怎么使用类的方法?其实就是创建一个对象,并且通过这个对象调用这个方法.不过这有一个问题,就是这个对象的载体就和这个对象产生了耦合,怎么降低两者间的耦合呢?java的反射机制就 ...
- java反射机制的理解
反射机制是什么概念?大多都有介绍,指的是程序在运行状态中,能够加载一个只有类名的类,加载完之后会在堆上产生一个Class对象.通过这个 Class对象可以获得类的属性.方法和其他类信息.之前对反射的应 ...
- Java反射的一些理解
1.Class对象 VS. 实例对象 在Java中我们一般是这样使用类的:编写类,然后new对象,再调用方法.这里new出来的对象暂且称之为实例对象(instance).其实在这之前还涉及到一个Cla ...
- JAVA反射机制_获取字节码文件对象
是在运行状态中,对于任意一个类 (class文件),都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性: 这种动态获取的信息以及动态调用对象的方法的功能称为java语 ...
- Java反射机制获取Class文件
JAVA反射机制是在运行状态中,对于任意一个类(class文件),都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象方法的功能称为 ...
- java反射机制 + Method.invoke解释 getMethod + 反射理解
功能: 通过读取另一个Dll去创建一个控件(Form,Button,TextBox,DataGridView),然后对当中一些属性进行检查. 创建控件的大致流程是,Assembly->Modul ...
- (转)JAVA反射机制理解
JAVA反射机制: 通俗地说,反射机制就是可以把一个类,类的成员(函数,属性),当成一个对象来操作,希望读者能理解,也就是说,类,类的成员,我们在运行的时候还可以动态地去操作他们. 理论的东东太多也没 ...
随机推荐
- 859. Buddy Strings - LeetCode
Question 859. Buddy Strings Solution 题目大意: 两个字符串,其中一个字符串任意两个字符互换后与另一个字符串相等,只能互换一次 思路: diff 记录不同字符数 两 ...
- 差分优化建边(Tax)
[Luogu P6822PA2012]Tax] (http://www.luogu.com.cn/problem/P6822") All right. Let's go! 题目描述 给出一个 ...
- Seata源码分析——SessionManager
目录 事务管理器 SessionManager SessionLifecycleListener AbstractSessionManager 事务存储管理器 RedisTransactionStor ...
- fiddler的安装以及使用同时对Android 与IOS 抓包配置进行分析 进阶 一
由于工作方向的原因,很久没有用过APP抓包工具了,有那么一天遇到了bug需要协助开发工程师进行定位分析,然后又重新梳理了一下之前常用的抓包工具,这里重点介绍一下目前市面上最流行的几款抓包工具,根据自己 ...
- while循环结构
一.循环: 1.场景: ①.用户名和密码,反复输入 ②.计算1-100之间 ③.游戏,重生 ④.-- 2.方式 ①.while ②.for 3.while格式 while 条件:要循环执行的代码 布尔 ...
- RocketMQ的基本使用
第一步导入依赖: <!--Springboot 集成 RocketMQ依赖--> <dependency> <groupId>org.apache.rocketmq ...
- FlinkSQL 之乱序问题
乱序问题 在业务编写 FlinkSQL 时, 非常常见的就是乱序相关问题, 在出现问题时,非常难以排查,且无法稳定复现,这样无论是业务方,还是平台方,都处于一种非常尴尬的地步. 在实时 join 中, ...
- 【原创】SpringBoot 2.7.0通过lettuce及commons-pool2 v2.9.0集成Redis踩坑记录
背景 公司的一个项目由于HTTPS证书到期,导致小程序.POS不能正常使用.所以百度了下,通过URL检测证书有效期的代码,并自行整合到一个服务中. 代码仓库:[基于SpringBoot + 企业微信 ...
- 合宙AIR105(二): 时钟设置和延迟函数
目录 合宙AIR105(一): Keil MDK开发环境, DAP-Link 烧录和调试 合宙AIR105(二): 时钟设置和延迟函数 Air105 的时钟 高频振荡源 芯片支持使用内部振荡源, 或使 ...
- JavaScript与Node.js一起打造一款聊天App
聊天是我们人与人交流最直接的方式,互联网的加入使我们交流更加便捷.我们手机上的微信.QQ是我们手机必不可少的应用软件.那么,我们是否可以做一款聊天应用呢? 之前我自己闲着没事,研究过一些技术,做了一款 ...