目录

Java中的反射机制

一丶什么是反射机制

  • 反射就是指Java在运行期间,可以获得类的一些信息.比如构造方法(私有共有...)以及属性

二丶Class类,自描述类.获取类名的三种方法

1.使用静态属性Class获取

代码:

	Class cls = Person.class; //获取自描述类
String strClassName = cls.getName();获取类的包名 + 类名
输出(strClassName);

首先我们的Class类是自描述类.可以返回这个类的描述信息.

有很多方法.比如获取类名字,方法.构造等等.

2.使用Class方法 forName()获取自描述Class

public static void main(String[] args) throws Exception {
// TODO 自动生成的方法存根
Class cls = Class.forName("com.ibinary_01.Person");//传入完整类名获取Class
String clsName = cls.getName();
System.out.println(clsName);
}

可以看到,我们使用forName必须传入完整的类名.

3.使用Object自带的getClass返回自描述Class

  • 因为我们的类,继承了Object,所以需要实例,进行调用getClass方法.

    代码如下
public static void main(String[] args) throws Exception {
// TODO 自动生成的方法存根
Class cls = new Person().getClass();
String clsName = cls.getName();
System.out.println(clsName);
}

三个的输出结果都一样,演示一下

三丶了解一下自描述类Class方法.

1.Class针对包,类,父类.接口的方法



通过以上图片可以看到. 我们可以获得包的路径. 我们上面使用的getName(); 那么我们还可以使用getSuperclss();

获得父类自描述类(Class),然后继续调用getName();获取父类的名称.

代码例子如下:

	public static void main(String[] args) throws Exception {
// TODO 自动生成的方法存根
Class cls = new Person().getClass();
Class supercls = cls.getSuperclass();
System.out.println(supercls.getName());
}

当然,我使用的是getClass();首先获得自己的Class,然后在获取父类的Class,最后调用父类的Class的getName();获得类名.

我们也可以使用上面所说的三种方法.

2.Class对构造方法提供的方法



可以看到,以上是我们Class为构造方法提供的方法获取.

3.Class对方法提供的方法.

上面标题有点绕,反正就是对我们的类的方法.提供方法去操作.或者获取.

4.Class对成员变量提供的方法

一样的,对我们的成员变量也提供了方法操作.

5.对内部类提供的方法

总结

  1. 针对我们的类,方法.构造.以及成员方法都提供了方法支持.首先要熟悉类的操作.
  2. 在通过getFilds()和getMethods()方法一次获得权限为public的成员变量和方法的时候.将包含从父类中继承到的成员变量和方法.也就是说会获得父类的公共方法和成员变量
  3. getDeclaredFields()和GETdeclaredMethods();只是获得奔雷中定义的所有成员变量和方法.

四丶反射访问构造方法

  • 方面我们讲了,Class中提供了对构造方法的支持.返回Constructior这个类.
  • 这个类也提供了对构造方法的操作.

1.构造方法类提供的方法.

构造方法



请注意 newInstance.我们可以利用指定参数.创建一个该类对象.在以后的安卓逆向中.可能会需要.

2.Modifier类

这个类则是传入类型则是调用Construct类中的getModifiers();返回构造方法的类型.传入.然后可以判断是什么属性.

提供的方法



  • 四种获得构造方法方式代码

    四种获得构造方法,其实是Class类提供的方法.在我们一开始已经截图给出了.

    具体就是代码例子使用了.

1.获取所有公共权限的构造方法

public static void main(String[] args) throws Exception {
// TODO 自动生成的方法存根
getAllConstruct(Person.class); }
static void getAllConstruct(Class<?> cls) {
//第一种,获得所有的构造方法
Constructor c[] = cls.getConstructors();
//遍历输出
for(Constructor i:c) {
System.out.println(i);
} }

可以看到,上边调用的就是getConstructors():获得了所有公共权限的方法,进行遍历输出了.

输出结果:

2.获取公共权限指定的构造方法

private static void getPublicConstruct(Class<Person> cls) {
// TODO 自动生成的方法存根
try {
Constructor<Person> c = cls.getConstructor(String.class,int.class);//获取指定公共权限的Construct
c.newInstance("1",2); //创建构造方法,并且调用 } catch (Exception e) {
e.printStackTrace();
}
}

获取公共的权限的指定构造方法,我们就需要传入类型的Class. 比如参数为 int.Class 代表一个参数.

下方调用newInstance();就是在使用这个构造.

3.获取所权限的构造方法,放到数组中

	private static void getAllConstruct(Class<Person> cls) {
// TODO 自动生成的方法存根
Constructor a[] = cls.getDeclaredConstructors();
for(Constructor i:a) {
System.out.println(i);
}
}

输出结果:

4.获取指定的构造方法

获得指定的就跟上面一样.比如这次我们获得priate权限的方法.并且调用它.

	private static void getPrivateConstructAnNewInstance(Class<Person> cls) throws InstantiationException, IllegalAccessException {
// TODO 自动生成的方法存根 try {
Constructor<Person> a = cls.getDeclaredConstructor(int.class,int.class,int.class);//获得指定的
a.setAccessible(true);
a.newInstance(1,1,1);
} catch (Exception e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} }

首先我们要使用 getDeclaredConstructor(int.Class...);获取指定的构造方法

因为是私有的,所以我们要使用构造方法类提供的 setAccessible(true);设置为共有的.

此时我们在使用newInstance(对应参数类型的参数); 即可实现调用.

结果图:

5.获取构造方法所有参数类型

其实这个方法上面也提供了.叫做 getParameterTypes();这个方法返回一个Class数组.

我们遍历这个数组即可.

private static void getPrivateConstructAnNewInstance(Class<Person> cls) throws InstantiationException, IllegalAccessException {
// TODO 自动生成的方法存根 try {
Constructor<?>[] a = cls.getConstructors();
for(Constructor i:a) {
System.out.println("构造函数 = " + i);//输出构造函数
Class Par[] = i.getParameterTypes();
for(Class j:Par) {
System.out.print(" " + j);//输出参数类型
}
System.out.println();
} } catch (Exception e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
} }

输出结果:

五丶成员变量的获取以及使用

1.获取所有公共权限成员变量

private static void getPublicAllFields(Class<Person> cls) {
// TODO 自动生成的方法存根
Field[] f = cls.getFields();//获取所有成员变量
for(Field i:f) {
System.out.println(i);
}
}

使用方法getFields()即可.输出之后会显示所有的名字.

2.获取公共权限指定的成员变量

使用方法: getField(String name);

	private static void getPublicAllFields(Class<Person> cls) {
// TODO 自动生成的方法存根
Field f;
try {
f = cls.getField("pid");
System.out.println(f);
} catch (Exception e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}

结果同上,我们需要传入名字才可以.

3.获取所有权限的成员变量

private static void getPublicAllFields(Class<Person> cls) {
// TODO 自动生成的方法存根
Field a[] = cls.getDeclaredFields();
for(Field i:a) {
System.out.println(i);
}
}

输出结果:

4.获得指定权限的成员变量

	private static void getPublicAllFields(Class<Person> cls) {
// TODO 自动生成的方法存根
try {
Field a = cls.getDeclaredField("name");
System.out.println(a);
} catch (Exception e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}

5.设置跟使用成员变量

我们上面可以获取.但是我们要使用.或者要更改值.

二个步骤.

1.获取Cls new出来的实例对象.

2.使用Set方法设置值.

如果设置私有,则要设置权限才可以.

private static void getPublicAllFields(Class<Person> cls) throws Exception {
// TODO 自动生成的方法存根
Object obj = cls.newInstance();
try {
Field a = cls.getDeclaredField("name");
a.setAccessible(true); //使用私有就要设置权限.
a.set(obj, "张三");
System.out.println(a.get(obj));//并且获取设置的成员变量值.
} catch (Exception e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}
}

结果:

Java开发知识之JAVA的反射的更多相关文章

  1. Java开发知识之Java中的Map结构

    Java开发知识之Java中的Map结构 一丶Map接口 Map没有实现Collection接口,提供的是Key 到Value的映射. Map中.不能包含相同的Key,每个Key只能映射一个Value ...

  2. Java开发知识之Java中的集合Set接口以及子类应用

    ---恢复内容开始--- Java开发知识之Java中的集合Set接口以及子类应用 一丶Set接口以及作用 在上一讲.我们熟悉了接口的实现图.以及自己各有的子类. List接口主要存储的数据是可以重复 ...

  3. Java开发知识之Java中的集合上List接口以及子类讲解.

    Java开发知识之Java中的集合类 一丶什么是集合类 如果你学习说数据结构,那么学习集合就很简单. 因为集合就是存储数据的结构. 例如 有链表结构 (list ) 还有 map结构.等等. 集合类就 ...

  4. Java开发知识之Java中的泛型

    Java开发知识之Java中的泛型 一丶简介什么是泛型. 泛型就是指泛指任何数据类型. 就是把数据类型用泛型替代了. 这样是可以的. 二丶Java中的泛型 Java中,所有类的父类都是Object类. ...

  5. Java开发知识之Java的枚举

    Java开发知识之Java的枚举 一丶什么是枚举 枚举可以理解为就是常量,在Java中我们定义常量.都是用 final语句. C++中都是用const关键字. 枚举跟C++概念都是一样的.就是特定的常 ...

  6. Java开发知识之Java的异常处理

    Java开发知识之Java的异常处理 一丶异常概述 在讲解异常之前,我们要搞清楚.什么是异常. 通俗理解就是我们编写的程序出问题了.进行处理的一种手段. 比如我们的QQ.有的时候就崩溃了.比如出现xx ...

  7. Java开发知识之Java类的高级特性,内部类.以及包使用.跟常量关键字

    Java开发知识之Java类的高级特性,内部类.以及包使用.跟常量关键字 一丶Java中包的机制 首先包其实就是个文件夹.作用就是管理类. Java中每次定义一个类的时候.通过Java编译之后.都会生 ...

  8. Java开发知识之Java的继承多态跟接口*

    Java开发知识之Java的继承多态跟接口 一丶继承 1.继承的写法 在Java中继承的 关键字是 extends 代表一个类继承另一个类. 继承的含义以及作用: 继承就是基于某个父类的扩展.制定出来 ...

  9. Java开发知识之Java的数字处理类Math类

    Java开发知识之Java的数字处理类Math类 一丶Java.text.DecimalFormat类与NumberFormat类 首先 Java.text.DecimalFormat指的是Decim ...

  10. Java开发知识之Java的包装类

    Java开发知识之Java的包装类 一丶什么是包装类 包装类的意思就是对基本数据类型封装成一个类.这些类都是Number的子类.区别就是封装数据类型不同.包含的方法基本相同. 具体可以查询JAVA A ...

随机推荐

  1. JS正则表达式检验数字或者带小数点的数字

    1. var patrn = /^\d+(\.\d+)?$/; var num = 0.11; if (!patrn.exec(num)){ alert("请您输入数字");ret ...

  2. 详解微信小程序开发(项目从零开始)

    一.序 微信小程序,估计大家都不陌生,现在应用场景特别多.今天就系统的介绍一下小程序开发.注意,这里只从项目代码上做解析,不涉及小程序如何申请.打包.发布的东西.(这些跟着微信官方文档的流程走就好). ...

  3. MySQL 中 having 和 where 的区别

    区别一: where 是数据从磁盘读入内存时候一条一条判断的 having 是将所有数据读入内存,在分组统计前,根据having的条件再将不符合条件的数据删除 区别二: having 子句可以使用字段 ...

  4. Object-C 编程问题汇总

    Object-C 编程问题汇总 Cocopods 安装时遇见的问题: error: RPC failed; curl 56 LibreSSL SSL_read: SSL_ERROR_SYSCALL, ...

  5. 老桂.net core系列课程

    为了支持"首届dnc开源峰会"(dncNew.com)顺利举办,本人<.net core系列课程>进行一波优惠,每个课程优惠在立即购买上方,领取现金券即可.课程地址为腾 ...

  6. 利用redis + lua解决抢红包高并发的问题

    抢红包的需求分析 抢红包的场景有点像秒杀,但是要比秒杀简单点.因为秒杀通常要和库存相关.而抢红包则可以允许有些红包没有被抢到,因为发红包的人不会有损失,没抢完的钱再退回给发红包的人即可.另外像小米这样 ...

  7. Java线程池核心原理剖析

    在系统开发时,我们经常会遇到“池”的概念.使用池一种以空间换时间的做法,通常在内存中事先保存一系列整装待命的对象,以供后期供其他对象随时调用.常见的池有:数据库连接池,socket连接池,线程池等.今 ...

  8. [Swift]LeetCode655. 输出二叉树 | Print Binary Tree

    Print a binary tree in an m*n 2D string array following these rules: The row number m should be equa ...

  9. [Swift]LeetCode860. 柠檬水找零 | Lemonade Change

    At a lemonade stand, each lemonade costs $5. Customers are standing in a queue to buy from you, and ...

  10. [Swift]LeetCode922.按奇偶排序数组 II | Sort Array By Parity II

    Given an array A of non-negative integers, half of the integers in A are odd, and half of the intege ...