首先介绍一下。什么是代理:

代理模式,是经常使用的设计模式。

特征是。代理类与托付类有同样的接口,代理类主要负责为托付类预处理消息、过滤消息、把消息转发给托付类。以及事后处理消息。

代理类和托付类,存在着关联关系。代理类的对象本身并不真正实现服务,知识通过调用托付类的对象的相关方法。

代理类能够分为两种:静态代理和动态代理。

静态代理:

代理类是由程序猿创建,或由工具生成的代码 编译成的。

在程序执行前,代理类的 *.class文件已经存在了。直接就能够执行 。

动态代理:

动态代理的代理类。

没有直接由源码生成。动态代理类的对象是在程序执行时由JAVA反射机制动态生成。不须要手工编写源码。从而提高了软件的可扩展性。JAVA反射机制能够生成随意类型的动态代理类。

静态代理的实现:

接口:

package test.static.pattern;

public interface UserManager {

	public void addUser(String userId,String userName);

	public void delUser(String userId);

	public String findUser(String userId);

	public void modifyUser(String userId,String userNameString);
}

实现类:

package test.static.pattern;

public class UserManagerImpl implements UserManager {

	@Override
public void addUser(String userId, String userName) {
System.out.println("UserManagerImpl.addUser() userId-->>" + userId);
} @Override
public void delUser(String userId) {
System.out.println("UserManagerImpl.delUser() userId-->>" + userId);
} @Override
public String findUser(String userId) {
System.out.println("UserManagerImpl.findUser() userId-->>" + userId);
return null;
} @Override
public void modifyUser(String userId, String userNameString) {
System.out.println("UserManagerImpl.modifyUser() userId-->>" + userId);
} }

静态代理类:(仅仅持有对象的引用)

package test.static.pattern;

public class UserManagerImplProxy implements UserManager {

	private UserManager userManager;

	public UserManagerImplProxy	(UserManager userManager){
this.userManager=userManager;
} @Override
public void addUser(String userId, String userName) {
userManager.addUser(userId, userName);
} @Override
public void delUser(String userId) {
userManager.delUser(userId);
} @Override
public String findUser(String userId) { return userManager.findUser(userId);
} @Override
public void modifyUser(String userId, String userNameString) {
userManager.modifyUser(userId, userNameString);
} }

client:

package test.static.pattern;

public class Client {
/**
* @param args
*/
public static void main(String[] args) {
//正常思路:client直接实例化出 子类的对象
UserManager userManager=new UserManagerImpl();
//静态代理:client实例化代理。通过代理取 子类的引用
UserManager userManager=new UserManagerImplProxy(new UserManagerImpl());
userManager.addUser("0001", "张三");
}
}

运行结果:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast">

静态代理,由于代理类持有对象的引用,所以能够对其进行控制。

现象1:对于各个功能模块来说,都要建立相应的代理类。造成大量的代理类

现象2:可是假设对各个实现同样的控制,则须要反复写大量的代码。

为了避免反复代码出现多次,我们接着看什么是动态代理。

动态代理的实现:

接口:

package test.dynamic.pattern;

public interface UserManager {

	public void addUser(String userId,String userName);

	public void delUser(String userId);

	public String findUser(String userId);

	public void modifyUser(String userId,String userNameString);
}

实现类:

package test.dynamic.pattern;

public class UserManagerImpl implements UserManager {

	@Override
public void addUser(String userId, String userName) {
System.out.println("UserManagerImpl.addUser() userId-->>" + userId);
} @Override
public void delUser(String userId) {
System.out.println("UserManagerImpl.delUser() userId-->>" + userId);
} @Override
public String findUser(String userId) {
System.out.println("UserManagerImpl.findUser() userId-->>" + userId);
return null;
} @Override
public void modifyUser(String userId, String userNameString) {
System.out.println("UserManagerImpl.modifyUser() userId-->>" + userId);
} }

动态代理生成类:

package test.dynamic.pattern;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy; import org.omg.CORBA.SystemException;
import org.omg.CORBA.portable.InputStream;
import org.omg.CORBA.portable.InvokeHandler;
import org.omg.CORBA.portable.OutputStream;
import org.omg.CORBA.portable.ResponseHandler; public class LogHandler implements InvocationHandler { /**
* 调用引用对象类的方法抽象
*/
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable { Object ret=null;
try {
//调用目标方法
ret=method.invoke(targetObject, args);
} catch (Exception e) {
throw e;
}
return ret;
} //目标实现的引用
private Object targetObject; /**
* 代理类生成方法
* @param targetObject
* @return
*/
public Object newProxyInstance(Object targetObject){
this.targetObject=targetObject;
return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(), targetObject.getClass().getInterfaces(), this);
}
}

client:

package test.dynamic.pattern;

public class Client {

	/**
* @param args
*/
public static void main(String[] args) {
//动态代理
LogHandler logHandler=new LogHandler();
UserManager userManager=(UserManager)logHandler.newProxyInstance(new UserManagerImpl());
//userManager.addUser("0001", "张三");
userManager.delUser("111");
}
}

运行结果:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast">

动态代理类,在程序中没有体现。

仅仅有在程序执行的时候採用创建对应的代理类。这样就能够少些大量的代理类。

对于现象2。同样控制代码是怎样降低的。请看下一篇博客。

深入浅出java静态代理和动态代理的更多相关文章

  1. Java深入浅出系列(四)——深入剖析动态代理--从静态代理到动态代理的演化

    静态代理 如上图,在程序执行之前.程序猿就要编写Proxy.然后进行编译,即在程序执行之前,代理类的字节码文件就已经生成了(Proxy类的class文件已经存在了). 静态代理尽管在增强现有的接口业务 ...

  2. 【Java】代处理?代理模式 - 静态代理,动态代理

    >不用代理 有时候,我希望在一些方法前后都打印一些日志,于是有了如下代码. 这是一个处理float类型加法的方法,我想在调用它前打印一下参数,调用后打印下计算结果.(至于为什么不直接用+号运算, ...

  3. Java:静态代理 and 动态代理

    代理模式是常用的设计模式,其特征是代理类与委托类具有相同的接口,在具体实现上,有静态代理和动态代理之分.代理类与委托类之间通常会存在关联关系,一个代理类的对象与一个委托类的对象关联,代理类的对象本身并 ...

  4. Java基础-静态代理与动态代理比较

    JAVA的静态代理与动态代理比较 静态代理类: 由程序员创建或由特定工具自动生成源代码,再对其编译.在程序运行前,代理类的.class文件就已经存在了.动态代理类: 在程序运行时,运用反射机制动态创建 ...

  5. java中静态代理,动态代理知识的补充

    文章转载自:http://blog.csdn.net/jialinqiang/article/details/8950989 一.Java动态代理 相对于静态代理的代理类在编译时生成(.class文件 ...

  6. java静态代理与动态代理简单分析

    原创作品,可以转载,但是请标注出处地址http://www.cnblogs.com/V1haoge/p/5860749.html 1.动态代理(Dynamic Proxy) 代理分为静态代理和动态代理 ...

  7. 黑马程序员:Java基础总结----静态代理模式&动态代理

    黑马程序员:Java基础总结 静态代理模式&动态代理   ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 静态代理模式 public  class  Ts {   ...

  8. Java静态代理和动态代理

    今天介绍一下代理设计模式,在业务场景中使用代理模式的好处有很多,包括什么权限校验,事务管理等等,具体有什么好处大家自动百度吧,我这里只解释代理模式的设计原理.首先这个设计模式出来的时候先是静态代理模式 ...

  9. java中的静态代理和动态代理,入门整理

    静态代理和动态代理主要解决的问题是:在直接访问对象时带来的问题,其目的就是为其他对象提供一个代理以控制对某个对象的访问.代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后 ...

随机推荐

  1. 行为型设计模式之访问者模式(Visitor)

    结构 意图 表示一个作用于某对象结构中的各元素的操作.它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作. 适用性 一个对象结构包含很多类对象,它们有不同的接口,而你想对这些对象实施一些依 ...

  2. 华为上机测试题(表达式运算-java)

    PS:自己写的,自测试OK,供大家参考. 补充:数据解析的过程,评论区有更好的处理方式,可参考. /* * 输入一个表达式,3*8+7-2,没有括号 输出结果 */ /* 本程序暂不考虑容错处理 */ ...

  3. Windows环境Vim编辑器如何执行Ruby代码

    1.下载 Ruby 1.8.5(2006-8-25) for Windows: 在网页http://www.rubychina.net/downloads/ 上找到  --〉Ruby on Windo ...

  4. 解决provisional headers are shown问题

    前端通过ajax的get请求向后端发送数据,后端死活收不到. ajax代码如下: $.ajax({ url:"/news_list", type:"GET", ...

  5. web前端到底是什么?有前途吗

    web前端到底是什么? 某货: “前几年前端开发人员鱼目混杂,技术参差不齐,相对学习起来不规范,导致> 前端开发人员聚集,所以现在前端工种和工资还是没得到普遍重视,但近2年来,> > ...

  6. Web前端培训学习心得

    web前端工程师技术日趋成熟,越来越多的行业巨头正不断向web前端工程师示好,在未来几年,web前端将会以更多的形式渗透到我们生活中的方方面面,因此越来越多的从业者开始关注web前端开发行业,今天小编 ...

  7. 实现如下语法的功能:var a = (5).plus(3).minus(6); //2

    从汤姆大叔的博客里看到了6个基础题目:本篇是第5题 - 实现如下语法的功能:var a = (5).plus(3).minus(6); //2 解题关键: 1.理解使用(5)和5的区别 2.构造函数原 ...

  8. SpringCloud简介(一)

    一.SpringCloud简介 SpringCloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.负载均衡.微代理.事件总线.全局锁.决策竞选.分布式会话等等 ...

  9. 浅谈如何做好Bug回归验证?

    作为测试人员,我们都知道Bug的生命周期是: 我们都希望自己不仅有敏锐的洞察力能够全面的找出隐藏在软件中的bug,还希望自己有系统的分析能力能够准确的分析出每个bug的原因以至于能正确.全面的解决修复 ...

  10. 关于spring.net的面向切面编程 (Aspect Oriented Programming with Spring.NET)-切入点(pointcut)API

    本文翻译自Spring.NET官方文档Version 1.3.2. 受限于个人知识水平,有些地方翻译可能不准确,但是我还是希望我的这些微薄的努力能为他人提供帮助. 侵删. 让我们看看 Spring.N ...