百度百科
代理模式的定义:为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不适合或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用。
image.png
代理模式的作用:
1、功能增强:在原有功能上增加额外的功能
2、控制访问:代理类不让访问目标类
实现代理的方式
静态代理:
1.自己手工实现,自己创建一个java类,表示代理类。
2.同时所要代理的目标类是确定的。
代理类完成的功能:
1.目标类中方法的调用
2.功能的增强
优缺点:
优点:实现简单,容易理解
缺点:当项目中,目标类和代理类很多的时候
1)当目标类增加,代理类可能需要成倍增加
2)当接口中功能怎加或修改,会影响众多实现类,厂家类,代理类都需要修改
代码实现:
实现步骤:
1.创建一个接口,定义卖U盘的方法,表示厂家和商家做的事情
2.创建厂家类,实现1的接口
3.创建商家,就是代理,也需要实现1中的接口
4.创建客户端类,调用商家的方法买一个优盘
创建一个接口
//表示功能,厂家,商家都要完成
public interface UsbSell {
/**
*
* @param amount 一次购买的数量
* @return 返回值表示一个优盘的价格
*/
float sell(int amount);
}
创建目标类
/**
* @author :star
* @description:TODO 目标类:u盘厂家,厂家不接受用户单独购买
* @date :2020/8/6 20:22
*/
public class UsbKingFactory implements UsbSell {
@Override
public float sell(int amount) {
//一个优盘价格85元
return 85.0f;
}
}
创建代理类
/**
* @author :star
* @description:TODO 淘宝商家,代理U盘厂家销售
* @date :2020/8/6 20:26
*/
public class TaoBao implements UsbSell {
//声明商家代理的厂家具体是谁
private UsbKingFactory factory = new UsbKingFactory();
@Override
//实现销售u盘的功能
public float sell(int amount) {
//向厂家发送订单,告诉厂家,我买了u盘,厂家发货
float price = factory.sell(amount);//厂家的价格
//商家需要加价,代理增加价格
price = price + 25;//增强功能
//在目标类的方法调用后,你做的其他功能,都是增强的意思
System.out.println("淘宝商家给你返了一优惠卷");
return price;
}
}
写一个主方法测试
public class ShopMain {
public static void main(String[] args) {
//创建代理商家taobaod对象
TaoBao taoBao = new TaoBao();
float price = taoBao.sell(1);
System.out.println("通过淘宝商家,购买u盘单价" + price) ;
}
}
运行结果
image.png
动态代理:
当项目中,目标类和代理类很多的时,可以避免静态代理的缺点。动态代理中目标类即使很多
1)代理类数量可以很少
2)当修改接口中的方法时,不会影响代理类
概念
动态代理:在程序执行过程中,使用jdk的反射机制,创建代理类对象,并动态的指定代理目类。换句话说,动态代理就是一种创建java对象的能力
动态代理的实现:
1.jdk动态代理:使用java 反射包中的类和接口实现动态代理功能
反射包java.lang.reflect,里面有三个类:InvocationHandler,Method,Proxy
2.cglib动态代理:cglib是第三方工具库,创建代理对象。cglib的原理是继承,通过继承目类,创建它的子类,在子类中重写父类中的同名方法,实现功能的修改
因为cglib是继承,重写方法,所以要求目标类不能是final的,方法也不能是final的,比如mybatis,spring框架中都有使用