用ReflectionFactory实现不调用构造参数创建对象

     那天在sun的论坛上漂着,不经意发现了一篇帖子,大概意思是想构造一个对象,但又不想或不能调用其构造方法.我把代码整理了一下,如下:
  
java 代码
 
  1. //Test.java  
  2. import java.io.Serializable;  
  3.    
  4. public class Test implements Serializable {  
  5.       
  6.     private Test() {  
  7.         System.out.println("Test");  
  8.     }  
  9.     public void say()  
  10.     {  
  11.         System.out.println("Hello!");  
  12.     }  
  13.       
  14. }  
java 代码
 
  1. //Main.java  
  2. import java.lang.reflect.Constructor;  
  3. import java.security.AccessController;  
  4. import sun.reflect.ReflectionFactory;  
  5.   
  6. public class Main {  
  7.   
  8.     private static final ReflectionFactory reflectionFactory = (ReflectionFactory) AccessController  
  9.             .doPrivileged(new ReflectionFactory.GetReflectionFactoryAction());  
  10.   
  11.     public static void main(String[] args) throws Exception {  
  12.         Constructor<test> constr = reflectionFactory  </test>
  13.                 .newConstructorForSerialization(Test.class, Object.class  
  14.                         .getConstructor(new Class[0]));  
  15.         Test test = (Test) constr.newInstance(new Object[0]);  
  16.         test.say();  
  17.     }  
  18. }  

      由于Test类的构造方法是private的,因此在Main类中无法调用其构造方法创建对象.用 ReflectionFactory可以给Test类动态创建一个构造方法,然后调用这个构造方法的newInstance方法创建对象.运行后我们可以发现,屏幕上打印出了"Hello",但并没有打印出 "Test".说明Test的原来的构造方法确实没被调用.

    是不是挺有意思的?
    然后用eclipse查看了一下 ReflectionFactory类中的方法,发现有许多有意思的方法.如:
newField,newMethod,等等. 但不知道参数具体是什么意思.但在google上,搜了半天,终于还是没有找到sun. reflect这个类库的api,或者相关说明.实在搞不明白,sun搞出来这么个类库,并且和java核心类库放在一起,但没有任何说明,不知道是让谁用的.
### Java反射技术在设计模式中的应用分析 #### 1. 反射技术概述 Java反射是一种强大的机制,允许程序在运行时动态获取类的信息并操作其字段、方法和构造函数[^1]。通过反射,开发者可以在知道具体类名的情况下创建对象调用方法或访问属性。 #### 2. 设计模式中的反射应用 以下是几种常见的设计模式及其如何利用反射技术的具体场景: ##### (1) 工厂模式(Factory Pattern) 工厂模式的核心在于隐藏对象创建的细节,并提供统一的对象生成接口。当需要支持多种类型的对象实例化时,可以通过反射来实现灵活的扩展。 ```java public class ReflectionFactory { public static Object createInstance(String className) throws Exception { Class<?> clazz = Class.forName(className); return clazz.getDeclaredConstructor().newInstance(); } } ``` 上述代码展示了基于反射的简单工厂实现方式[^5]。客户端只需传入目标类的全限定名称即可获得其实例,而无需修改现有代码结构。 ##### (2) 单例模式(Singleton Pattern) 单例模式通常用于确保某个类只有一个实例存在。然而,在某些特殊情况下可能希望打破这一约束条件——比如测试环境下的多态需求,则可借助于反射绕过私有的无参构造器限制。 需要注意的是这种方法违背了原本的设计意图因此应谨慎使用。 ##### (3) 原型模式(Prototype Pattern) 原型模式适用于快速复制已有对象而必重新初始化整个过程的情形下。如果待克隆的目标含有复杂嵌套关系或者依赖外部资源加载的话那么单纯依靠浅拷贝难以满足实际要求;此时引入深拷贝配合序列化加反序列化的手段便显得尤为重要。与此同时还可以考虑运用反射完成更深层次上的定制化配置工作。 ##### (4) 解释器模式(Interpreter Pattern) 解释器模式旨在构建一种能够解析特定语法规则的语言处理器框架体系。在此过程中可避免涉及到大量节点类型定义以及相应求值逻辑编写任务。为了简化维护成本提高灵活性往往倾向于采用策略组合形式即把每种运算符对应的操作封装成独立单元再由高层调度执行从而达到松耦合的目的。这里就可以充分发挥反射的优势自动探测匹配合适的算法组件进而减少硬编码带来的麻烦[^3]。 #### 3. 总结 综上所述可以看出合理运用好反射确实有助于增强系统的适应性和鲁棒性但是同时也伴随着一定风险诸如安全性降低效率下降等问题所以在真正项目实践中务必要权衡利弊做出明智抉择[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值