java的代理模式(静态和动态代理)

1.静态代理
(1)公共接口

package com.ming.proxy;
/*
 * 公共接口
 */
public interface Kill {
    String kill();
    void say();
}

(2)委托类

package com.ming.proxy;
/*
 * 委托类:我想要杀一个人但是不想亲自动手,委托给别人来做,雇佣杀手,Killer类
 */
public class Mine implements Kill {

    @Override
    public String kill() {
        System.out.println("我想要杀一个人。。。");
        return "mine";
    }

    @Override
    public void say() {
        System.out.println("我是mine");
    }

}

(3)静态代理类
(代理类持有委托类对象,并实现了相同的接口,从而控制委托类的方法)

package com.ming.proxy;
/**
 * 
* @ClassName: Killer 
* @Description: TODO(代理类:杀手) 
* @author chenliming
* @date 2017年6月27日 上午10:20:13 
*
 */
public class Killer implements Kill {
    private Mine mine;

    public Killer(Mine mine) {
        super();
        this.mine = mine;
    }

    @Override
    //杀手可以决定怎么执行刺杀任务
    public String kill() {
        System.out.println("刺杀前准备");
        mine.kill();
        System.out.println("刺杀后处理");
        return "killer";
    }

    @Override
    public void say() {
        System.out.println("我是杀手");
    }

}

(4)执行代码

package com.ming.proxy;

import org.junit.Test;
/*
 * 静态代理:
 * 1.委托类和代理类实现相同的接口;
 * 2.代理类持有委托类的对象
 */
public class TestProxy {
    @Test
    /*
     * 测试静态代理模式
     */
    public void testStaticProxy() {
        //委托类
        Mine mine = new Mine();
        //代理类
        Killer killer = new Killer(mine);
        killer.kill();
    }

}

2.jdk动态代理
(1)生成动态代理的类

package com.ming.proxy;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

public class MyInvocationHandler implements InvocationHandler {
    private Object obj = null;
    /*
     * 生成代理对象
     */
    public Object bind(Object obj) {
        this.obj = obj;
        //生成代理对象参数(类加载器,类的所有接口,InvocationHandler对象)
        return Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj.getClass().getInterfaces(), this);
    }

    @Override
    /**
     * 动态代理对象执行的方法,可以随意增强或者改变方法的执行
     */
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        if("kill".equals(method.getName())) {
            System.out.println("=====before=====");
            Object temp = method.invoke(this.obj, args);
            System.out.println("=====after======");
            return "动态代理的改变返回值";//可以改变返回值
        } else {
            return null;
        }

    }
}

(2)执行代码

package com.ming.proxy;

import org.junit.Test;
/*
 * 静态代理:
 * 1.委托类和代理类实现相同的接口;
 * 2.代理类持有委托类的对象
 */
public class TestProxy {
    @Test
    /*
     * 测试静态代理模式
     */
    public void testStaticProxy() {
        //委托类
        Mine mine = new Mine();
        //代理类
        Killer killer = new Killer(mine);
        killer.kill();
    }
    @Test
    /*
     * 测试java动态代理模式
     */
    public void testDyProxy() throws Exception {
        MyInvocationHandler demo = new MyInvocationHandler();
        Kill subject = (Kill) demo.bind(new Mine());
        String temp = subject.kill();
        System.out.println(temp);
        subject.say();

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值