专注Java教育14年 全国咨询/投诉热线:400-8080-105
动力节点LOGO图
始于2009,口口相传的Java黄埔军校
首页 hot资讯 初识动态代理模式

初识动态代理模式

更新时间:2022-06-07 10:12:47 来源:动力节点 浏览499次

初步了解动态代理设计模式

1.代理模式

(1)目的:代理模式的目的是为其他对象提供一个代理来控制对该对象的访问。使用代理包装对象并将原始对象替换为代理对象。对原始对象的任何调用都是通过代理进行的。代理对象决定是否以及何时将方法调用转移到原始对象。

(2)主要解决方案:直接访问对象时出现的问题,例如:要访问的对象在远程机器上。在面向对象的系统中,有些对象由于某种原因(例如,对象创建成本高,某些操作需要安全控制,或者进程外访问),直接访问会给用户或系统结构带来很多麻烦,当我们访问它时,我们可以为这个对象添加一个访问层。

(3)何时使用:你想在访问一个类时做一些控制。

(4)优势:职责明确,扩展性高,智能化。

(5)缺点:由于在客户端和真实主体之间增加了代理对象,某些类型的代理模式可能会导致请求处理更慢;实现代理模式需要额外的工作,并且一些代理模式实现起来非常复杂。

2.静态代理

interface TicketOffice{
    void sellTicket();
}
// Proxy Class
class RailwayStation implements TicketOffice{
    @Override
    public void sellTicket() {
        System.out.println("The station really sold a ticket");
    }
}
// proxy class
class ProxyStation implements TicketOffice{
    private TicketOffice ticketOffice;
    public ProxyStation(TicketOffice ticketOffice){
        this.ticketOffice = ticketOffice;
    }    
    @Override
    public void sellTicket() {
        System.out.println("Work before ticket sales");
        ticketOffice.sellTicket();
        System.out.println("Work after ticket sale");
    }
}
// Test Class
public class StaticProxyTest {
    public static void main(String[] args) {
        // Create an object of a proxy class
        TicketOffice rs = new RailwayStation();
        // Object to create proxy class
        TicketOffice ps = new ProxyStation(rs);
        ps.sellTicket();
    }
}

3.动态代理

执行静态代理时,代理类和目标对象的类是在编译时确定的,不利于程序的扩展。同时,每个代理类只能服务一个接口,这样在程序的开发中难免会出现过多的代理。最好通过一个代理类来完成所有代理功能。

使用反射机制在运行时创建代理类的动态代理。

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
interface Hello {
    void sayHello();
}
// Proxy Class
class HelloImpl implements Hello{
    @Override
    public void sayHello() {
        System.out.println("Hello world!");
    }
}
class MyInvocationHandler2 implements InvocationHandler {
    private Object target; // Target object
    public MyInvocationHandler2(Object target){
        this.target = target;
    }
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("Pre-notification code");
        // Execute the appropriate target method
        Object rs = method.invoke(target, args);
        System.out.println("Post-processing code");
        return rs;
    }
}
public class ProxyTest2 {
    public static void main(String[] args) {
        HelloImpl helloImpl = new HelloImpl();
        Hello hello = (Hello) Proxy.newProxyInstance(Hello.class.getClassLoader(), new Class[]{Hello.class}, new MyInvocationHandler2(helloImpl));
        hello.sayHello();
    }
}

 

提交申请后,顾问老师会电话与您沟通安排学习

免费课程推荐 >>
技术文档推荐 >>