反射其实就是指在超脱规则的束缚,从强引用到弱相关,在上帝视角做事情,对于写配置文件,和一些框架的源码,得到调用上至关重要,java带有解释器的语法特性,使得泛型一类的语法糖和反射配合之后更如鱼得水!

反射其实就是通过获得一个类的Class对象来进行操作,从而得到Constructor(构造方法:包括非共有;private、无类型、protected)对象、Method(方法:包括非共有;private、无类型、protected)对象和Field(变量,这个解释我也觉得不够准确:包括非共有;private、无类型、protected)对象来进行我们能够想象的所有操作!

Class类

得到类名称,类的实现的接口,继承类。

获得Class对象的三种方式:

1.类名.class;(依赖性较强,需要其中的import的支持)

Class c1 = Student.class;

2.Class.forName("全类名");(通过forName来加载,依赖性比较低)

Class c2 = Class.forName("c_flect.entity.Student");

3.对象.getClass();(一种单纯使用大多数时候,比较鸡肋的方法:通过对象来获得Class对类对象)

Class c3 = new Student().getClass();

常用方法:

getName() 获得全类名
getSimpleName() 仅获得当前类名
getSuperclass() 获得父类的名称(全类名)

getInterfaces()

返回值是Class[]数组,所有实现接口
涉及Constructor的
getConstructor 获取特定公开构造方法
getConstructors 获取所有公开构造方法
getDeclaredConstructor 获取特定的声明构造(包括非公开)
getDeclaredConstructors 获取所有的声明构造(包括非公开)
涉及Method的
getMethod 获取特定公开方法
getMethods 获取所有公开方法
getDeclaredMethod 获取特定的声明方法(包括非公开)
getDeclaredMethods 获取所有的声明方法(包括非公开)
涉及到Field的
getField 获取特定公开变量
getFields 获取所有公开变量
getDeclaredField 获取特定的声明变量(包括非公开)
getDeclaredFields 获取所有的声明变量(包括非公开)
其中需要注意的点:

1.所有如果是私有的构造方法、方法和变量要先setAccessible(true);才能进行使用

2.在get constructor、method和feild的时候,所有其中的形参类型,都是类型的.class Class对象

3.constructor最后newInstance就行了,method执行时调用invoke,field执行时调用set

4.method执行和field执行都要在执行方法的第一个位置传参传入执行此方法的对象(此方法的提供对象)

开始贴代码,使用junit测试:

package c_flect;

import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.Method; import org.junit.Test; import c_flect.entity.Student; /**
* 反射复习:
* Class类,代表类。
* 得到类名称,类的实现的接口,继承类。
* Constructor类,代表类的构造方法。
* 构造对象。
* Method类,代表类的普通方法。
* 调用方法。
* Field类,代表类的属性。
* 得到属性值,设置属性值。
* @author mzy
*/
public class Demo01 {
/**
* Class类:
* 测试得到Class类对象的三种方式回忆!
*/
// @Test
public void test01() throws Exception {
// 1.依赖性较强,需要其中的import的支持
Class c1 = Student.class;
// 2.通过forName来加载,依赖性比较低
Class c2 = Class.forName("c_flect.entity.Student");
// 3.一种单纯使用大多数时候,比较鸡肋的方法:通过对象来获得Class对类对象
Class c3 = new Student().getClass(); // 得到类名
System.out.println(c1 == c2);
System.out.println(c2 == c3); System.out.println(c1.getName()); // 得到类的全名
System.out.println(c2.getSimpleName()); // 得到简单名
// 得到类的继承的结构:得到当前的Student的父类
System.out.println(c1.getSuperclass().getSimpleName()); // 得到类的接口
Class[] interArray = c1.getInterfaces();
for (Class c : interArray) {
System.out.println(c.getSimpleName());
}
} /**
* Constructor类:
* 构造对象
*/
@Test
public void test02() throws Exception {
// 通过Class类得到Constructor类
Class c = Class.forName("c_flect.entity.Student");
/*
* 获取所有的构造方法
* 但是获取到了所有的构造之后并并不好用,获取想要的才是最好的
* 统计有多少个构造方法可能有用。
*/
/*
Constructor[] constructors = c.getConstructors();
for(Constructor con : constructors) {
System.out.println(con);
}
*/ /*
* 1.调用无参构造
*/
Constructor cons1 = c.getConstructor(null);
// 通过Constructor构造对象
Object o1 = cons1.newInstance(null);
// System.out.println(o1.getClass().getSimpleName());
System.out.println(o1);
/*
* 2.调用有参构造:私有
*/
Constructor cons2 = c.getDeclaredConstructor(int.class, String.class);
// 设置这个私有构造的访问权限为true
cons2.setAccessible(true);
Object o2 = cons2.newInstance(19, "mzy");
// System.out.println(o2.getClass().getSimpleName());
System.out.println(o2);
} /**
* Method类:
* 类的普通方法,调用
*/
@Test
public void test03() throws Exception {
// 1.通过Class类 对象得到Method类对象
Class c = Class.forName("c_flect.entity.Student");
// Object o = c.getConstructor(null).newInstance(null);
/*
* 同上:只有无参构造才可以这样简化!
* 有参构造必须 先getConstructor
* 再newInstance这种形式,或者
* getConstructor(int.class, String.class).newInstance(20, "mzy");
*/
Object o = c.newInstance(); Method setName = c.getMethod("setName", String.class); // 如果有多个参数,跟在后面就行了
/*
* 2) 通过Method对象来调用方法
* Method对象调用方法
* 需要把要调用此方法的对象传入
* 后面跟上参数值
*/
setName.invoke(o, "mzy");
System.out.println(o); Constructor cons = c.getDeclaredConstructor(int.class, String.class, int.class);
cons.setAccessible(true); Object o2 = cons.newInstance(18, "zxr", 168);
Method getHeight = c.getDeclaredMethod("getHeight", null);
getHeight.setAccessible(true);
Object res = getHeight.invoke(o2, null);
System.out.println("height = "+res);
System.out.println(o2);
} /**
* Field类:
* 得到属性值,设置属性值。
*/
@Test
public void test04() throws Exception {
// 1) 通过Class得到Field类对象
Class c = Class.forName("c_flect.entity.Student");
// Object o = c.getConstructor(null).newInstance(null);
Object o = c.newInstance();
// 共有属性很简单,这里就演示非共有属性访问!
Field field = c.getDeclaredField("name");
field.setAccessible(true);
field.set(o, "mzy");
System.out.println(o);
}
}

其中调用的Student类:

package c_flect.entity;

public class Student implements Person, Child{
private int age;
private String name;
private int height; public Student() { } private Student(int age, String name) {
this.age = age;
this.name = name;
} private Student(int age, String name, int height) {
this.age = age;
this.name = name;
this.height = height;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} private int getHeight() {
return height;
} public void setHeight(int height) {
this.height = height;
} @Override
public String toString() {
return "Student [age=" + age + ", name=" + name + "]";
} }

mzy对于反射的复习的更多相关文章

  1. java 反射机制复习笔记。

    1.java 反射的作用(好处): (1)能够使我们很方便的创建灵活的代码,这些代码可以在运行时装配(运行时获取一个类实例),就不用在组件之间进行源代码链接了,大大提高系统的灵活性和扩展性. (2)与 ...

  2. 9.12DjangoORM回顾和路由.

    2018-9-12 13:44:41 周末继续整理一下博客!不知不觉记了好多! 越努力越幸运! 永远不要高估自己! 关于反射的复习 # /usr/bin/env python # -*- coding ...

  3. JNI_day02

    二级指针 指向指针变量的指针,保存指针的地址 结构体 struct Student //struct Stdent 学生结构体类型 { int id;//成员 char name[20]; int a ...

  4. JDBC01 获取数据库连接

    概述 Java Database Connectivity(JDBC)直接访问数据库,通用的SQL数据库存取和操作的公共接口,定义访问数据库的标准java类库(java.sql,javax.sql) ...

  5. 2018年底,IOS面试题的复习之OC的反射机制

    明天要去面试一个公司,今天复习下IOS题目吧 1.说一下OC的反射机制 答:OC的反射机制类似于JAVA的反射机制,这种动态反射机制可以让OC语言更加灵活.这句话是对反射机制的初步认识,具体表现在哪里 ...

  6. python 全栈开发,Day23(复习,isinstance和issubclass,反射)

    一.复习 class A: def func1(self):pass def func2(self): pass def func3(self): pass a = A() b = A() print ...

  7. java8--类加载机制与反射(java疯狂讲义3复习笔记)

    本章重点介绍java.lang.reflect包下的接口和类 当程序使用某个类时,如果该类还没有被加载到内存中,那么系统会通过加载,连接,初始化三个步骤来对该类进行初始化. 类的加载时指将类的clas ...

  8. Java基础复习笔记系列 十三 反射机制

    主题:Java反射机制 学习资料参考网址: 1.http://www.icoolxue.com 1.Java反射机制. 各种框架中都使用到了Java的反射机制. 两个类:java.lang.Class ...

  9. C#复习反射

    反射中常用方法: //获取对象类型 One one = new One(); Type t = one.GetType(); //动态加载 Assembly a = Assembly.LoadFile ...

随机推荐

  1. 论文阅读:LIC-Fusion: LiDAR-Inertial-Camera Odometry

    本文提出了一种紧耦合的多传感器(雷达-惯导-相机)融合算法,将IMU测量.稀疏视觉特征.提取的激光点融合.提出的算法在时间和空间上对三个异步传感器进行在线校准,补偿校准发生的变化.贡献在于将检测和追踪 ...

  2. 【LeetCode】724. 寻找数组的中心下标

    724. 寻找数组的中心下标 知识点:数组:前缀和: 题目描述 给你一个整数数组 nums ,请计算数组的 中心下标 . 数组 中心下标 是数组的一个下标,其左侧所有元素相加的和等于右侧所有元素相加的 ...

  3. Python开发篇——构建虚拟Python开发环境(Conda+Poetry)

    前言 之前虽略有提及Python,但是没有实际地写点料.惭愧,惭愧,所以这次先起个头,讲讲如何构建虚拟Python开发环境.相信之前看过我博客的人可能会想:博主不会又要聊聊Docker吧?放心,不会. ...

  4. C++第四十二篇 -- CPU Usage

    前言 目的:读取并控制CPU占用率 近期在做CPU Usage方面的事情,让CPU以一种高占用率的状态运行一定的时间,需要读取CPU各个核的占用率,网上关于这方面的资料好少,FQ也只找到了一个WMI的 ...

  5. Python基础之创建文件夹与删除文件夹。

    参考链接:https://blog.csdn.net/weixin_43826242/article/details/87101436 创建目录结构 # 创建文件目录结构 def create_fol ...

  6. ZooKeeper(2181、2171) 未授权访问

    下载地址http://archive.apache.org/dist/zookeeper/zookeeper-3.4.14/ tar -xzvf zookeeper-3.4.14.tar.gz cd ...

  7. 填坑-关于IIC通讯

    ​01.概述 在之前的文章中<STM32IIC详解>中详细讲解了IIC协议,并且使用是NXP的官方手册,demo示例使用IIC读取RTC芯片,运行正常,没有任何问题.并且更新了<II ...

  8. 2020年度钻石C++C学习笔记(1)《博学谷》

    1.C语言概述 1.1 什么是C语言 一提到语言这个词语,自然会想到的是像英语.汉语等这样的自然语言,因为它是人和人交换信息不可缺少的工具. 而今天计算机遍布了我们生活的每一个角落,除了人和人的相互交 ...

  9. 解决 OnDropFiles 可能无响应的问题【转】

    大多数程序都有接收拖放文件的功能,即是用鼠标把文件拖放到程序窗口上方,符合格式的文件就会自动被程序打开.最近自己对编写的程序增加了一个拖放文件的功能,在 Windows XP.Windows Serv ...

  10. JUC学习笔记(六)

    JUC学习笔记(一)https://www.cnblogs.com/lm66/p/15118407.html JUC学习笔记(二)https://www.cnblogs.com/lm66/p/1511 ...