静态代理
接口
public interface UserManager {
public void addUser(String username, String password);
public void modifyUser(int userId, String username, String password);
public String findUserById(int userId);
}
实现类
public class UserManagerImpl implements UserManager {
public void addUser(String username, String password) {
// System.out.println("start-->>addUser - username=" + username + ", password=" + password);
// try {
// //
// System.out.println("UserManagerImpl.addUser()");
// System.out.println("end-->>addUser() ");
// }catch(Exception e) {
// e.printStackTrace();
// System.out.println("error-->>addUser() ");
// throw new java.lang.RuntimeException();
// }
try {
System.out.println("UserManagerImpl.addUser()");
}catch(Exception e) {
e.printStackTrace();
throw new java.lang.RuntimeException();
}
}
public String findUserById(int userId) {
System.out.println("UserManagerImpl.findUserById()");
return null;
}
public void modifyUser(int userId, String username, String password) {
System.out.println("UserManagerImpl.modifyUser()");
}
}
代理
public class UserManagerImplProxy implements UserManager {
private UserManager userManager;
public UserManagerImplProxy(UserManager userManager) {
this.userManager = userManager;
}
public void addUser(String username, String password) {
System.out.println("start-->>addUser - username=" + username + ", password=" + password);
try {
userManager.addUser(username, password);
System.out.println("end-->>addUser() ");
}catch(Exception e) {
e.printStackTrace();
System.out.println("error-->>addUser() ");
}
}
public String findUserById(int userId) {
return null;
}
public void modifyUser(int userId, String username, String password) {
}
}
test
public class Client {
public static void main(String[] args) {
//UserManager userManager = new UserManagerImpl();
//userManager.addUser("张三", "123");
UserManager userManager = new UserManagerImplProxy(new UserManagerImpl() );
userManager.addUser("张三", "123");
}
}
代理 和 实现 都实现了共同的接口
代理在内部维护了一个实现,当调用代理的接口方法时,
代理在内部调用了它维护的实现类的方法,并加上自己的操作
静态代理需要一个个的写代理方法,不好用
动态代理
接口
public interface UserManager {
public void addUser(String username, String password);
public void modifyUser(int userId, String username, String password);
public String findUserById(int userId);
}
InvocationHandler
public class LogHandler implements InvocationHandler {
private Object targetObject;
public Object newProxyObject(Object targetObject) {
this.targetObject = targetObject;
return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(),
targetObject.getClass().getInterfaces(), this);
}
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
System.out.println("start-->>" + method.getName());
for (int i=0; i<args.length; i++) {
System.out.println(args[i]);
}
Object result = null;
try {
result = method.invoke(this.targetObject, args);
System.out.println("end-->>" + method.getName());
}catch(Exception e) {
e.printStackTrace();
System.out.println("error-->>" + method.getName());
}
System.out.println("result=" + result);
return result;
}
}
实现
public class UserManagerImpl implements UserManager {
public void addUser(String username, String password) {
// System.out.println("start-->>addUser - username=" + username + ", password=" + password);
// try {
// //
// System.out.println("UserManagerImpl.addUser()");
// System.out.println("end-->>addUser() ");
// }catch(Exception e) {
// e.printStackTrace();
// System.out.println("error-->>addUser() ");
// throw new java.lang.RuntimeException();
// }
try {
System.out.println("UserManagerImpl.addUser()");
}catch(Exception e) {
e.printStackTrace();
throw new java.lang.RuntimeException();
}
}
public String findUserById(int userId) {
System.out.println("UserManagerImpl.findUserById()");
return "李四";
}
public void modifyUser(int userId, String username, String password) {
System.out.println("UserManagerImpl.modifyUser()");
}
}
test
public class Client {
public static void main(String[] args) {
//UserManager userManager = new UserManagerImpl();
//userManager.addUser("张三", "123");
//UserManager userManager = new UserManagerImplProxy(new UserManagerImpl() );
//userManager.addUser("张三", "123");
LogHandler handler = new LogHandler();
UserManager userManager = (UserManager)handler.newProxyObject(new UserManagerImpl());
//UserManagerImpl userManager = (UserManagerImpl)handler.newProxyObject(new UserManagerImpl());
//userManager.addUser("张三", "123");
//userManager.modifyUser(1, "张三", "123");
userManager.findUserById(1);
}
}
InvocationHandler中通过newProxyObject()得到了一个实现了接口的代理,
该代理能动态的代理接口中的方法,被代理对象只能时实现了接口的对象
有第3方组件可以代理一般java对象
分享到:
相关推荐
代理模式是一种设计模式,它在软件工程中扮演着重要的角色,允许我们为其他对象提供一个替代接口,以控制对原始对象的访问。这种模式的主要目的是为了增加灵活性、安全性或者在不修改原有对象的情况下,增强或扩展其...
代理模式是设计模式的一种,它提供了一种对目标对象进行增强或者控制访问的方式。在本实例中,我们将深入探讨Java中的代理模式及其应用。 代理模式的核心思想是为一个对象创建一个代理对象,这个代理对象在客户端和...
代理模式是设计模式中的一种结构型模式,它在对象交互中起到了中介的作用,允许通过代理对象来控制对原对象的访问。代理模式的核心思想是为一个对象提供一个替身,以便增加新的功能或者控制对原对象的访问。这种模式...
代理模式是设计模式的一种,它的主要目的是在不改变原有对象的基础上,为一个对象提供额外的功能或者控制对这个对象的访问。在Android开发中,代理模式的应用尤为常见,尤其在处理复杂的业务逻辑、网络请求、界面...
SignalR提供了两种主要的工作模式:代理模式和非代理模式。这两种模式在实现上有所不同,各自具有优缺点,适用于不同的场景。 **1. 代理模式(Proxy Mode)** 在代理模式下,SignalR为每个Hub(服务端的业务逻辑...
代理模式是一种常用的设计模式,它在软件开发中扮演着重要的角色,特别是在iOS平台的应用程序设计中。代理模式的核心思想是为一个对象提供一个替身或代理,以控制对这个对象的访问。这种模式允许我们通过代理来间接...
在Java编程中,代理模式是一种常用的面向对象设计模式,它允许我们为一个对象提供一个代理以控制对该对象的访问。代理模式通常用于增加额外的功能,如日志、权限检查等,或者为了创建虚拟代理以提高性能。以下是Java...
**Java设计模式——代理模式详解** 代理模式是软件设计模式中的一个重要组成部分,它在Java编程中扮演着举足轻重的角色。代理模式的核心思想是为一个对象提供一个替身,这个替身即代理对象,代理对象可以控制对原...
代理模式是一种设计模式,它在软件工程中扮演着重要的角色,允许我们为其他对象提供一个替代接口,以控制对原对象的访问。这种模式的主要目的是为了增加灵活性、安全性或者为对象提供额外的功能,同时保持客户端代码...
**设计模式之代理模式(Proxy Pattern)** 设计模式是软件工程中的一种最佳实践,它是在特定情境下解决常见问题的模板。代理模式是其中一种行为设计模式,它的核心思想是为一个对象提供一个替身或者代理,以控制对...
**设计模式实现——代理模式** 在软件工程中,设计模式是一种通用可重用的解决方案,它描述了在特定上下文中经常出现的问题以及该问题的解决方案。代理模式是设计模式的一种,它提供了一种对目标对象的间接访问方式...
代理模式是一种设计模式,属于结构型模式之一,其主要目的是为其他对象提供一个代理,以控制对该对象的访问。在实际应用中,代理模式能够帮助我们实现如下的功能: 1. 远程代理:代理对象可以代表一个位于远程系统...
在这个“Java设计模式-代理模式例子”中,我们将深入探讨代理模式的概念、实现方式以及它在实际开发中的应用。 代理模式的核心思想是为一个对象提供一个替身,这个替身即代理对象,代理对象控制对原对象的访问。在...
代理模式在软件设计中是一种常用的设计模式,尤其在Android开发中,它可以帮助我们实现复杂的控制逻辑,隔离复杂性,以及提供额外的功能。在Android上下文中,代理模式常常用于数据加载、权限控制、事件处理等方面。...
代理模式是一种设计模式,它是结构型模式之一,主要用于在客户端和目标对象之间建立一个代理对象,以便控制对目标对象的访问。在C++中,代理模式可以用来为其他对象提供一种代理以控制对这个对象的访问,或者增加...
### Java代理模式与Java动态代理详解 #### 一、代理模式概述 代理模式是一种软件设计模式,它在客户端和目标对象之间提供了一种间接层。这种模式的主要目的是控制客户端对目标对象的访问,并且可以在不修改原有...
代理模式是一种常用的设计模式,它在软件开发中扮演着重要角色,允许我们通过一个代理类来控制对原对象的访问。在《设计模式:可复用面向对象软件的基础》(通常称为GoF设计模式)中,代理模式被定义为“为其他对象...
代理模式(Proxy) 定义: 为其他对象提供一种代理以控制对这个对象的访问 结构: 由三部分组成 1.RealSubject(真实对象): 真正会调用到的对象 2.Proxy(代理对象): 代理真实对象的地方 3.Subject(共同点): 代理对象...
在IT行业中,代理模式是一种常见的设计模式,它允许我们在不修改原有对象的基础上,为对象添加新的功能或控制访问。在本示例中,我们将重点讨论如何在Java环境下使用代理模式来实现代理逻辑,特别是在CAS(Central ...