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反射机制: 通俗地说,反射机制就是可以把一个类,类的成员(函数,属性),当成一个对象来操作,希望读者能理解,也就是说,类,类的成员,我们在运行的时候还可以动态地去操作他们. 理论的东东太多也没 ...
随机推荐
- 992. Sort Array By Parity II - LeetCode
Question 992. Sort Array By Parity II Solution 题目大意:给一个int数组,一半是奇数一半是偶数,分别对偶数数和奇数数排序并要求这个数本身是偶数要放在偶数 ...
- 23. Merge k Sorted Lists - LeetCode
Question 23. Merge k Sorted Lists Solution 题目大意:合并链表数组(每个链表中的元素是有序的),要求合并后的链表也是有序的 思路:遍历链表数组,每次取最小节点 ...
- sqlserver2008 数据库中查询存储过程的的创建修改和执行时间,以及比较常见的系统视图和存储过程
因为各种原因数据库中存在大量无用的存储过程,想查询存储过程的最后执行情况,处理长期不使用的存储过程 下面这条语句可以查询存储过程创建 修改和执行的最后时间: SELECT a.name AS 存储过程 ...
- Netty是什么,Netty为什么速度这么快,线程模型分析
哈喽!大家好,我是小奇,一位热爱分享的程序员 小奇打算以轻松幽默的对话方式来分享一些技术,如果你觉得通过小奇的文章学到了东西,那就给小奇一个赞吧 文章持续更新 一.前言 书接上回,现在下着大雨看来是去 ...
- springcloud-- Alibaba-nacos--支持的几种服务消费方式
通过<Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现>一文的学习,我们已经学会如何使用Nacos来实现服务的注册与发现,同时也介绍如何通过LoadBal ...
- Kubernetes client-go DeltaFIFO 源码分析
概述Queue 接口DeltaFIFO元素增删改 - queueActionLocked()Pop()Replace() 概述 源码版本信息 Project: kubernetes Branch: m ...
- 使用 cookie 的身份验证和授权
前言 在上一章 学学 dotnet core 中的身份验证和授权-1-概念 中,我们大致明白了身份验证和授权两者的关系.那么在本文中,我们将使用 cookie 来做一个简单的身份验证和授权. 本文中我 ...
- Python with语句和上下文管理器
open("FishC.txt","w")#此处需注意如果被打开的文件中,已有内容,那么用w的方式打开,则会导致原文件内容被截断,也就是相当于被清空了,然后重新 ...
- 大数据分析VMWare虚拟机centos系统下配置网络参数
最近搞大数据方面的数据,通过网上视频学习和自己实践,有些不成文的实践就零碎的记录在此吧. 系统也可安装CentOS DVD版. 1.先进入配置文件,并查看基本情况,如下: 2.用vi编辑器打开物理网卡 ...
- Oracle常见问题解决方法
1.设置数据库用户的密码有效期为 无限制 --查询proile文件名 SELECT username,PROFILE FROM dba_users; --查询文件 的密码保护策略 SELECT * F ...