- 浏览: 1017564 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (826)
- 硬件 (8)
- 软件 (24)
- 软件工程 (34)
- JAVA (229)
- C/C++/C# (77)
- JavaScript (8)
- PHP (1)
- Ruby (3)
- MySQL (14)
- 数据库 (19)
- 心情记事 (12)
- 团队管理 (19)
- Hadoop (1)
- spring (22)
- mybatis(ibatis) (7)
- tomcat (16)
- velocity (0)
- 系统架构 (6)
- JMX (8)
- proxool (1)
- 开发工具 (16)
- python (10)
- JVM (27)
- servlet (5)
- JMS (26)
- ant (2)
- 设计模式 (5)
- 智力题 (2)
- 面试题收集 (1)
- 孙子兵法 (16)
- 测试 (1)
- 数据结构 (7)
- 算法 (22)
- Android (11)
- 汽车驾驶 (1)
- lucene (1)
- memcache (12)
- 技术架构 (7)
- OTP-Erlang (7)
- memcached (17)
- redis (20)
- 浏览器插件 (3)
- sqlite (3)
- Heritrix (9)
- Java线程 (1)
- scala (0)
- Mina (6)
- 汇编 (2)
- Netty (15)
- libevent (0)
- CentOS (12)
- mongod (5)
- mac os (0)
最新评论
-
kingasdfg:
你这里面存在一个错误添加多个任务 应该是这样的 /** * ...
Quartz的任务的临时启动和暂停和恢复【转】 -
kyzeng:
纠正一个错误,long型对应的符号是J,不是L。
Jni中C++和Java的参数传递 -
zhaohaolin:
抱歉,兄弟,只是留下作记录,方便学习,如果觉得资料不好,可以到 ...
netty的个人使用心得【转】 -
cccoooccooco:
谢谢!自己一直以为虚机得使用网线才可以与主机连接呢。。
主机网卡无网线连接与虚拟机通信 -
yuqilin001:
要转别人的东西,请转清楚点嘛,少了这么多类,误人子弟
netty的个人使用心得【转】
委托模式
是软件设计模式中的一项基本技巧。在委托模式中,有两个对象参与处理同一个请求,接受请求的对象将请求委托给
另一个对象来处理。委托模式是一项基本技巧,许多其他的模式,如状态模式、策略模式、访问者模式本质上是在更特殊的场合采用了委托模式。委托模式使得我们
可以用聚合来替代继承,它还使我们可以模拟mixin。
“委托”在C#中是一个语言级特性,而在Java语言中没有直接的对应,但是我们可以通过动态代理来实现委托!代码如下:
- import java.lang.reflect.InvocationHandler;
- import java.lang.reflect.Method;
- import java.lang.reflect.Proxy;
- /*
- * @author Liusheng
- * 实现“委托”模式,用户需要实现InvocationHandler接口;
- * 参考:http://www.uml.org.cn/j2ee/200411036.htm
- */
- public abstract class Delegator implements InvocationHandler {
- //RelegateTo针对每个对象都要生成一个实例,因而非Static的log,代价比较高。
- //protected Log _log = LogFactory.getLog(this.getClass());
- //private static Log _log = LogFactory.getLog(RelegateTo.class);
- //--------------------------------------------
- protected Object obj_orgin = null ; //原始对象
- protected Object obj_proxy = null ; //代理对象
- //--------------------------------------------
- public Delegator() {
- //空
- }
- public Delegator(Object orgin){
- this .createProxy(orgin);
- }
- //--------------------------------------------
- protected Object createProxy(Object orgin) {
- obj_orgin = orgin;
- obj_proxy = Proxy.newProxyInstance(
- orgin.getClass().getClassLoader(), //加载器
- orgin.getClass().getInterfaces(), //接口集
- this ); //委托
- //_log.debug("# 委托代理:"+obj_proxy);
- return obj_proxy;
- }
- protected Object invokeSuper(Method method, Object[] args)
- throws Throwable {
- return method.invoke(obj_orgin, args);
- }
- //--------------实现InvocationHandler接口,要求覆盖------------
- public Object invoke(Object obj, Method method, Object[] args)
- throws Throwable {
- // 缺省实现:委托给obj_orgin完成对应的操作
- if (method.getName().equals( "toString" )) { //对其做额外处理
- return this .invokeSuper(method, args)+ "$Proxy" ;
- }else { //注意,调用原始对象的方法,而不是代理的(obj==obj_proxy)
- return this .invokeSuper(method, args);
- }
- }
- }
import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; /* * @author Liusheng * 实现“委托”模式,用户需要实现InvocationHandler接口; * 参考:http://www.uml.org.cn/j2ee/200411036.htm */ public abstract class Delegator implements InvocationHandler { //RelegateTo针对每个对象都要生成一个实例,因而非Static的log,代价比较高。 //protected Log _log = LogFactory.getLog(this.getClass()); //private static Log _log = LogFactory.getLog(RelegateTo.class); //-------------------------------------------- protected Object obj_orgin = null; //原始对象 protected Object obj_proxy = null; //代理对象 //-------------------------------------------- public Delegator() { //空 } public Delegator(Object orgin){ this.createProxy(orgin); } //-------------------------------------------- protected Object createProxy(Object orgin) { obj_orgin = orgin; obj_proxy = Proxy.newProxyInstance( orgin.getClass().getClassLoader(), //加载器 orgin.getClass().getInterfaces(), //接口集 this); //委托 //_log.debug("# 委托代理:"+obj_proxy); return obj_proxy; } protected Object invokeSuper(Method method, Object[] args) throws Throwable { return method.invoke(obj_orgin, args); } //--------------实现InvocationHandler接口,要求覆盖------------ public Object invoke(Object obj, Method method, Object[] args) throws Throwable { // 缺省实现:委托给obj_orgin完成对应的操作 if (method.getName().equals("toString")) { //对其做额外处理 return this.invokeSuper(method, args)+"$Proxy"; }else { //注意,调用原始对象的方法,而不是代理的(obj==obj_proxy) return this.invokeSuper(method, args); } } }
下面的代码,则是作为一个委托的例子,实现Map的功能。
- import java.io.IOException;
- import java.lang.reflect.Method;
- import java.util.Hashtable;
- import java.util.Map;
- import org.apache.commons.logging.Log;
- import org.apache.commons.logging.LogFactory;
- import com.bs2.core.UtilLog;
- /**
- * @author Liusheng
- * 本代码主要用于演示RelegateTo的使用方法
- */
- public class Delegator4Map extends Delegator {
- private static Log _log = LogFactory.getLog(Delegator4Map. class );
- private Map orginClass = null ; //原始对象
- private Map proxyClass = null ; //代理对象
- public Map getOrgin() { return orginClass; }
- public Map getProxy() { return proxyClass; }
- public Delegator4Map(Map orgin) {
- super (orgin);
- orginClass = orgin;
- proxyClass = (Map)super .obj_proxy;
- }
- public Object invoke(Object obj, Method method, Object[] args)
- throws Throwable {
- if (method.getName().equals( "size" )) { //修改close处理逻辑
- _log.debug("原始 size()=" + super .invoke(obj, method, args));
- Object res2 = new Integer(- 1 );
- _log.debug("修改 size()=" +res2);
- return res2;
- }else {
- return super .invoke(obj, method, args);
- }
- }
- public static void main(String[] args) throws IOException {
- UtilLog.configureClassPath("resources/log4j.properties" , false );
- Delegator4Map rtm = new Delegator4Map( new Hashtable());
- Map m = rtm.getProxy();
- m.size();
- _log.debug("代理:" +m.toString());
- }
- }
import java.io.IOException; import java.lang.reflect.Method; import java.util.Hashtable; import java.util.Map; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import com.bs2.core.UtilLog; /** * @author Liusheng * 本代码主要用于演示RelegateTo的使用方法 */ public class Delegator4Map extends Delegator { private static Log _log = LogFactory.getLog(Delegator4Map.class); private Map orginClass = null; //原始对象 private Map proxyClass = null; //代理对象 public Map getOrgin() { return orginClass; } public Map getProxy() { return proxyClass; } public Delegator4Map(Map orgin) { super(orgin); orginClass = orgin; proxyClass = (Map)super.obj_proxy; } public Object invoke(Object obj, Method method, Object[] args) throws Throwable { if (method.getName().equals("size")) { //修改close处理逻辑 _log.debug("原始 size()="+super.invoke(obj, method, args)); Object res2 = new Integer(-1); _log.debug("修改 size()="+res2); return res2; }else { return super.invoke(obj, method, args); } } public static void main(String[] args) throws IOException { UtilLog.configureClassPath("resources/log4j.properties", false); Delegator4Map rtm = new Delegator4Map(new Hashtable()); Map m = rtm.getProxy(); m.size(); _log.debug("代理:"+m.toString()); } }
注意:UtilLog仅仅是用于配置log4j属性文件位置,如果log4j.properties就在缺省的运行路径下,则无需单独配置。或者用System.out输出来替代_log输出。
发表评论
-
调试jdk中的源码,查看jdk局部变量
2013-06-15 23:30 1055调试jdk中的源码,查看jdk局部变量 2012-04 ... -
Eclipse快捷键 10个最有用的快捷键<转>
2013-04-11 23:28 1082Eclipse中10个最有用的快捷键组合 一个Eclip ... -
Lucene 3.6 中文分词、分页查询、高亮显示等
2012-12-09 23:35 18241、准备工作 下载lucene 3.6.1 : htt ... -
Maven实战(九)——打包的技巧(转)
2012-10-12 00:41 941“打包“这个词听起 ... -
基于Maven的web工程如何配置嵌入式Jetty Server开发调试环境(转)
2012-10-12 00:28 9421、首先在web工程的POM文件里添加依赖jar包如下: ... -
轻轻松松学Solr(1)--概述及安装[转]
2012-09-18 14:59 998概述 这段时间对企 ... -
分析Netty工作流程[转]
2012-09-04 19:02 893下面以Netty中Echo的例 ... -
让eclipse在ubuntu下面好看一点
2012-03-27 10:17 925<p> </p> <h1 cla ... -
zookeeper安装和应用场合(名字,配置,锁,队列,集群管理)[转]
2012-01-12 17:59 1653安装和配置详解 本文 ... -
Jakarta-Common-BeanUtils使用笔记[转]
2012-01-10 14:13 1160Jakarta-Common-BeanUtils ... -
一个关于Java Thread wait(),notify()的实用例【转】
2012-01-07 16:05 1024///// // ProducerConsume ... -
Java基础:Java中的 assert 关键字解析【转】
2012-01-06 19:50 1066J2SE 1.4在语言上提供了 ... -
一篇不错的讲解Java异常的文章(转载)----感觉很不错,读了以后很有启发[转]
2012-01-06 15:02 1272六种异常处理的陋习 ... -
如何解决HP QC(Quality Center)在Windows 7下不能工作的问题
2011-12-26 10:48 1588HP QC(Quantity Center) 是一款不错的测 ... -
JAVA读写文件,中文乱码 【转】
2011-12-19 23:43 2123最近在做HTML静态生成,需要从硬盘上把模版文件的内容读出来。 ... -
Java 6 JVM参数选项大全(中文版)【转】
2011-12-19 19:51 974Java 6 JVM参数选项大全(中文版) 作者 ... -
使用assembly plugin实现自定义打包【转】
2011-12-13 01:58 975在上一篇文章中,讨论到在对maven的机制不熟悉的情况下,为了 ... -
使用maven ant task实现非标准打包[转]
2011-12-13 01:56 1050maven很强大,但是总有些事情干起来不是得心应手,没有使用a ... -
Java日期转换SimpleDateFormat格式大全【转】
2011-12-08 20:22 131924小时制时间 显示: public clas ... -
使用Spring的表单标签库
2011-11-22 20:08 107813.9. 使用Spring的 ...
相关推荐
本项目旨在通过Java的动态代理技术实现面向切面编程(AOP),涵盖了静态代理、JDK动态代理、CGLIB动态代理、AspectJ以及基于instrumentation的动态代理等多种实现方式。通过这些实现方式,可以在不修改原有代码的...
在Java中,代理类和委托类通常实现相同的一组接口,这样代理类就可以代替委托类被客户端调用,而客户端无须知道实际处理请求的对象是代理还是委托。 **Proxy类**: 1. `getInvocationHandler`: 获取指定代理对象...
Java的代理模式通过代理类提供了对委托类的扩展和控制,静态代理适合对已有代码不做修改的情况,而动态代理则提供了更高的灵活性和扩展性。在实际应用中,应根据项目需求和性能考虑选择静态代理或动态代理。对于需要...
4. **使用动态代理实例**:通过动态代理实例调用相应的方法,这些方法会被代理类转发到委托类进行实际执行。 #### 动态代理类的生成与实现 当调用`Proxy.newProxyInstance`方法时,Java虚拟机会根据传入的`...
在Java中,`java.util.Observable` 类和 `java.util.Observer` 接口提供了一个实现观察者模式的基础框架。当被观察的对象(Subject)状态改变时,它会调用 `notifyObservers()` 方法,将变化通知给所有注册的观察者...
Java动态代理是一种强大的设计模式,它允许我们在运行时创建具有特定行为的代理对象。这种模式在处理如AOP(面向切面编程)、事件监听、事务管理等场景中非常有用。动态代理主要有两种实现方式:JDK动态代理和CGLIB...
这一机制使得开发者无需手动编写代理类代码,只需指定一组接口和目标对象(委托类),就能动态生成实现了这些接口的代理类实例。 Proxy类是Java动态代理的核心,它提供了以下几个关键的静态方法: 1. `...
无论是静态代理还是动态代理,它们都是代理模式的具体实现形式。选择哪种方式取决于具体的应用场景和技术需求。静态代理适用于功能较为固定的场景,而动态代理则更适合于需要高度灵活性和可扩展性的应用。理解这两种...
Java中的代理模式是一种设计模式,它允许我们创建一个代理对象,该对象可以在调用实际对象的方法之前或之后执行额外的操作,而无需修改原始代码。在Java中,代理主要分为静态代理和动态代理。 1. 静态代理: 静态...
Java代理机制允许我们在运行时动态创建一个实现了一组给定接口的新类,这个新类可以作为原类的代理,提供额外的功能,如日志、事务管理或者,如题目中所述,权限控制。JDK代理是Java标准库提供的一个实现,位于`java...
Java动态代理机制是一种在运行时创建代理类和代理对象的技术,它允许我们为已存在的接口创建代理实现,以便在调用接口方法时添加额外的功能或行为。这种模式在软件开发中非常有用,尤其是在需要扩展已有功能,比如...
总结一下,`JAVA代理`涉及到的主要知识点包括: 1. **静态代理**:手动创建代理类,通过代理类对目标对象进行方法调用的拦截和增强。 2. **动态代理**:利用Java的`Proxy`类和`InvocationHandler`接口,动态地创建...
### JAVA23中设计模式详解 #### 一、概述 设计模式是在软件设计过程中解决常见问题的一套可复用的解决方案。《JAVA23中设计模式》是一份针对Java程序员的指南,旨在通过一系列示例和理论讲解,帮助读者理解和掌握...
在Java中,我们可以使用静态代理和动态代理来实现这一目的。 **静态代理** 静态代理是在编译时就确定了代理类的结构,代理类的源代码是程序员手动编写或者由特定工具自动生成的。代理类需要实现与目标类相同的接口...
### Java代理技术详解:JDK代理、CGLIB与AspectJ #### 一、代理模式简介 代理模式是一种常见的设计模式,在《Design Patterns in Java》一书中对其有明确的定义:“代理模式为一个对象提供一个代理,以控制对该...
在提供的`ProxyTest`文件中,可能包含了这样的示例代码,演示了如何创建和使用动态代理。你可以通过查看和运行这段代码来加深对动态代理的理解。 总结来说,动态代理是Java中一种强大的设计模式,它允许我们为现有...
总的来说,Java的动态代理机制提供了一种动态实现设计模式和增强对象功能的方法,减少了代码冗余,提高了代码的可维护性和可扩展性。它是一个强大且未充分利用的工具,值得开发者深入了解和熟练掌握。