广告
返回顶部
首页 > 资讯 > 后端开发 > Python >java反射详解(3)
  • 678
分享到

java反射详解(3)

反射详解java 2023-01-31 00:01:48 678人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

动态代理 【案例】首先来看看如何获得类加载器:  class test{       } class hello{     public static void main(String[] args) {         test t=ne

动态代理

【案例】首先来看看如何获得类加载器: 

  1. class test{ 
  2.       
  3. class hello{ 
  4.     public static void main(String[] args) { 
  5.         test t=new test(); 
  6.         System.out.println("类加载器  "+t.getClass().getClassLoader().getClass().getName()); 
  7.     } 

【程序输出】:

类加载器  sun.misc.Launcher$AppClassLoader

其实在java中有三种类类加载器。

1)Bootstrap ClassLoader 此加载器采用c++编写,一般开发中很少见。

2)Extension ClassLoader 用来进行扩展类的加载,一般对应的是jre\lib\ext目录中的类

3)AppClassLoader 加载classpath指定的类,是最常用的加载器。同时也是java中默认的加载器。

如果想要完成动态代理,首先需要定义一个InvocationHandler接口的子类,已完成代理的具体操作。

  1. package Reflect; 
  2. import java.lang.reflect.*; 
  3.   
  4. //定义项目接口 
  5. interface Subject { 
  6.     public String say(String name, int age); 
  7.   
  8. // 定义真实项目 
  9. class RealSubject implements Subject { 
  10.     @Override 
  11.     public String say(String name, int age) { 
  12.         return name + "  " + age; 
  13.     } 
  14.   
  15. class MyInvocationHandler implements InvocationHandler { 
  16.     private Object obj = null; 
  17.   
  18.     public Object bind(Object obj) { 
  19.         this.obj = obj; 
  20.         return Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj 
  21.                 .getClass().getInterfaces(), this); 
  22.     } 
  23.   
  24.     @Override 
  25.     public Object invoke(Object proxy, Method method, Object[] args) 
  26.             throws Throwable { 
  27.         Object temp = method.invoke(this.obj, args); 
  28.         return temp; 
  29.     } 
  30.   
  31. class hello { 
  32.     public static void main(String[] args) { 
  33.         MyInvocationHandler demo = new MyInvocationHandler(); 
  34.         Subject sub = (Subject) demo.bind(new RealSubject()); 
  35.         String info = sub.say("Rollen", 20); 
  36.         System.out.println(info); 
  37.     } 

【运行结果】:

Rollen  20

类的生命周期

在一个类编译完成之后,下一步就需要开始使用类,如果要使用一个类,肯定离不开JVM。在程序执行中JVM通过装载,链接,初始化这3个步骤完成。

类的装载是通过类加载器完成的,加载器将.class文件的二进制文件装入JVM的方法区,并且在堆区创建描述这个类的java.lang.Class对象。用来封装数据。 但是同一个类只会被类装载器装载以前

链接就是把二进制数据组装为可以运行的状态。

 

链接分为校验,准备,解析这3个阶段

校验一般用来确认此二进制文件是否适合当前的JVM(版本),

准备就是为静态成员分配内存空间,。并设置默认值

解析指的是转换常量池中的代码作为直接引用的过程,直到所有的符号引用都可以被运行程序使用(建立完整的对应关系)

完成之后,类型也就完成了初始化,初始化之后类的对象就可以正常使用了,直到一个对象不再使用之后,将被垃圾回收。释放空间。

当没有任何引用指向Class对象时就会被卸载,结束类的生命周期

反射用于工厂模式

先来看看,如果不用反射的时候,的工厂模式吧:

Http://www.cnblogs.com/rollenholt/arcHive/2011/08/18/2144851.html

  1.  
  2.   
  3. interface fruit{ 
  4.     public abstract void eat(); 
  5.   
  6. class Apple implements fruit{ 
  7.     public void eat(){ 
  8.         System.out.println("Apple"); 
  9.     } 
  10.   
  11. class Orange implements fruit{ 
  12.     public void eat(){ 
  13.         System.out.println("Orange"); 
  14.     } 
  15.   
  16. // 构造工厂类 
  17. // 也就是说以后如果我们在添加其他的实例的时候只需要修改工厂类就行了 
  18. class Factory{ 
  19.     public static fruit getInstance(String fruitName){ 
  20.         fruit f=null; 
  21.         if("Apple".equals(fruitName)){ 
  22.             f=new Apple(); 
  23.         } 
  24.         if("Orange".equals(fruitName)){ 
  25.             f=new Orange(); 
  26.         } 
  27.         return f; 
  28.     } 
  29. class hello{ 
  30.     public static void main(String[] a){ 
  31.         fruit f=Factory.getInstance("Orange"); 
  32.         f.eat(); 
  33.     } 
  34.   

这样,当我们在添加一个子类的时候,就需要修改工厂类了。如果我们添加太多的子类的时候,改的就会很多。

现在我们看看利用反射机制:

  1. package Reflect; 
  2.   
  3. interface fruit{ 
  4.     public abstract void eat(); 
  5.   
  6. class Apple implements fruit{ 
  7.     public void eat(){ 
  8.         System.out.println("Apple"); 
  9.     } 
  10.   
  11. class Orange implements fruit{ 
  12.     public void eat(){ 
  13.         System.out.println("Orange"); 
  14.     } 
  15.   
  16. class Factory{ 
  17.     public static fruit getInstance(String ClassName){ 
  18.         fruit f=null; 
  19.         try{ 
  20.             f=(fruit)Class.forName(ClassName).newInstance(); 
  21.         }catch (Exception e) { 
  22.             e.printStackTrace(); 
  23.         } 
  24.         return f; 
  25.     } 
  26. class hello{ 
  27.     public static void main(String[] a){ 
  28.         fruit f=Factory.getInstance("Reflect.Apple"); 
  29.         if(f!=null){ 
  30.             f.eat(); 
  31.         } 
  32.     } 

现在就算我们添加任意多个子类的时候,工厂类就不需要修改。

 

上面的例子虽然可以通过反射取得接口的实例,但是需要传入完整的包和类名。而且用户也无法知道一个接口有多少个可以使用的子类,所以我们通过属性文件的形式配置所需要的子类。

下面我们来看看: 结合属性文件的工厂模式

首先创建一个fruit.properties的资源文件,

内容为:

  1. apple=Reflect.Apple 
  2. orange=Reflect.Orange 

 然后编写主类代码: 

  1. package Reflect; 
  2.   
  3. import java.io.*; 
  4. import java.util.*; 
  5.   
  6. interface fruit{ 
  7.     public abstract void eat(); 
  8.   
  9. class Apple implements fruit{ 
  10.     public void eat(){ 
  11.         System.out.println("Apple"); 
  12.     } 
  13.   
  14. class Orange implements fruit{ 
  15.     public void eat(){ 
  16.         System.out.println("Orange"); 
  17.     } 
  18.   
  19. //操作属性文件类 
  20. class init{ 
  21.     public static Properties getPro() throws FileNotFoundException, IOException{ 
  22.         Properties pro=new Properties(); 
  23.         File f=new File("fruit.properties"); 
  24.         if(f.exists()){ 
  25.             pro.load(new FileInputStream(f)); 
  26.         }else{ 
  27.             pro.setProperty("apple", "Reflect.Apple"); 
  28.             pro.setProperty("orange", "Reflect.Orange"); 
  29.             pro.store(new FileOutputStream(f), "FRUIT CLASS"); 
  30.         } 
  31.         return pro; 
  32.     } 
  33.   
  34. class Factory{ 
  35.     public static fruit getInstance(String ClassName){ 
  36.         fruit f=null; 
  37.         try{ 
  38.             f=(fruit)Class.forName(ClassName).newInstance(); 
  39.         }catch (Exception e) { 
  40.             e.printStackTrace(); 
  41.         } 
  42.         return f; 
  43.     } 
  44. class hello{ 
  45.     public static void main(String[] a) throws FileNotFoundException, IOException{ 
  46.         Properties pro=init.getPro(); 
  47.         fruit f=Factory.getInstance(pro.getProperty("apple")); 
  48.         if(f!=null){ 
  49.             f.eat(); 
  50.         } 
  51.     } 

【运行结果】:Apple

 

--结束END--

本文标题: java反射详解(3)

本文链接: https://www.lsjlt.com/news/182857.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • java反射详解(3)
    动态代理 【案例】首先来看看如何获得类加载器:  class test{       } class hello{     public static void main(String[] args) {         test t=ne...
    99+
    2023-01-31
    反射 详解 java
  • Java 反射(Reflect)详解
    目录一 首先我们的去知道什么是反射?二(刨根问底)知道是什么还需要知道什么“成分”组成反射?2.1 Class 对象的获取及使用2.2 拿到碗筷就得去盛饭,拿到了Class就得去操作...
    99+
    2022-11-12
  • Java反射机制详解
    目录类的声明周期不同阶段都可以获取类对象获取Class类对象的方式的场景class类对象的功能如何获取私有变量的值根据有无主方法判断进程和线程反射出现的背景(记住)反射出现的背景类的...
    99+
    2022-11-13
  • Java反射技术详解
    目录前言一、基本反射技术1.1 根据一个字符串得到一个类getClass方法Class.forNameType属性二、获取类的成员获取类中特定的构造方法调用构造方法调用类的私有方法获...
    99+
    2022-11-12
  • 【Java 基础篇】Java 反射详解
    文章目录 导言一、反射的概念二、反射的原理三、反射的使用示例四、反射的应用场景五、反射的注意事项总结 导言 Java反射是指在运行时动态地获取类的信息,并可以通过该信息来操作类或对象。...
    99+
    2023-09-14
    java python 开发语言
  • java反射超详细讲解
    目录Java反射超详解✌1.反射基础1.1Class类1.2类加载2.反射的使用2.1Class对象的获取2.2Constructor类及其用法2.4Method类及其用...
    99+
    2022-11-12
  • java反射机制最详解
    目录java反射机制什么是反射?反射的功能:反射常用类:1.Class枚举类2.Constructor构造器3.Method方法类4.Field变量类反射运行指示图通过反射获取对象总结java反射机制 什么是反射? 在java开发中有一个...
    99+
    2020-08-07
    java java反射机制
  • 超详细解释Java反射
    目录一、什么是反射1. 反射机制的功能2. 实现反射机制的类二、反射的使用1. Customer类2. ReflectTester类三、具体实例1. ReflexDemo类2. Wr...
    99+
    2022-11-12
  • Java基础之反射详解
    目录前言一、一个需求引出反射二、反射入门三、反射原理图四、反射相关类五、反射调用优化前言 反射是我们框架的灵魂,反射也是我们框架的一个底层基石,没有反射也就没有框架,如果我们学好了反...
    99+
    2022-11-12
  • Java-反射机制(超详解)
    Java反射机制概述 前言一、Java反射机制概述1. Java Reflection2. 动态语言 vs 静态语言 二、 Class类的理解1. 类的加载过程1.1 初步了解1.2 类的加载过程图解1.3 了解:什么时候会发...
    99+
    2023-08-17
    java 开发语言
  • Java反射 PropertyDescriptor类案例详解
    JAVA中反射机制(JavaBean的内省与BeanUtils库) 内省(Introspector) 是Java 语言对JavaBean类属性、事件的一种缺省处理方法。 JavaB...
    99+
    2022-11-12
  • Java反射机制基础详解
    目录1、什么是Java反射机制?2、反射机制原理3、Class类介绍3.1、Class类基本介绍3.2、Class类对象的获取方法Class.forname()3.3、可以获取Cla...
    99+
    2022-11-12
  • Java中的反射机制详解
    目录一、什么是反射?二、为什么要用反射三、Class类四、获取Class类对象的四种方式五.通过反射构造一个类的实例①使用Class.newInstance②通过反射先获取构造方法再...
    99+
    2022-11-12
  • 详解Java反射创建对象
    一、什么是反射 Java Reflaction in Action中的解释:反射是运行中的程序检查自己和软件运行环境的能力,它可以根据它发现的进行改变。通俗的讲就是反射可以在运行时根...
    99+
    2022-11-12
  • Java反射(超详细!)
    1、反射机制有什么用? 通过java语言中的反射机制可以操作字节码文件(可以读和修改字节码文件。) 通过反射机制可以操作代码片段。(class文件。) 2、反射机制的相关类在哪个包下? java.lang.reflect.*; 3、反射机制...
    99+
    2023-08-18
    java
  • Java 反射机制详解及实例
    Java 反射机制详解及实例反射,当时经常听他们说,自己也看过一些资料,也可能在设计模式中使用过,但是感觉对它没有一个较深入的了解,这次重新学习了一下,感觉还行吧!      &n...
    99+
    2023-05-31
    java 反射机制 ava
  • Java 反射机制的实例详解
    Java 反射机制的实例详解前言 今天介绍下Java的反射机制,以前我们获取一个类的实例都是使用new一个实例出来。那样太low了,今天跟我一起来学习学习一种更加高大上的方式来实现。正文 Java反射机制定义Java反射机制是指在运行状态中...
    99+
    2023-05-31
    java 反射机制 ava
  • 详解PHP反射API
    PHP中的反射API就像Java中的java.lang.reflect包一样。它由一系列可以分析属性、方法和类的内置类组成。它在某些方面和对象函数相似,比如get_class_vars(),但是更加灵活,而且可以提供更多信息。反射API也可...
    99+
    2023-09-02
    php 开发语言
  • C#反射(Reflection)详解
    目录一.System.Type类1.Type属性2.方法二.Assembly类1.获取在程序集中定义的类型的详细信息2.获取自定义特性的详细信息1.编写自定义特性2.对VectorC...
    99+
    2022-11-13
  • Java方法反射实现原理详解
    博主说:Java 反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为 Java 语言的反射机制。在本文中,占小狼分析了 J...
    99+
    2023-05-31
    java 方法反射 ava
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作