博客
关于我
Spring 静态代理与 动态代理 【在理解为学习AOP奠定基础】(七)
阅读量:233 次
发布时间:2019-03-01

本文共 2072 字,大约阅读时间需要 6 分钟。

Spring AOP 代理模式学习

代理模式

代理是通知目标对象后创建的对象。从客户端的角度看,代理对象和目标对象是一样的。

静态代理

出租房屋

public interface Rent { 
void Renthouse();
}

房东类

public class Host implements Rent {
@Override
public void Renthouse() {
System.out.println("房东有一套房子出租!!!");
}
}

代理类

public class Proxy implements Rent {
private Host host;
public Proxy(Host host) {
this.host = host;
}
@Override
public void Renthouse() {
host.Renthouse();
Money();
seeHose();
hetong();
}
public void Money() {
System.out.println("中介-收取一定的报酬会");
}
public void seeHose() {
System.out.println("中介-带我看房子。");
}
public void hetong() {
System.out.println("满意的话,签合同!");
}
}

测试类

public class client {
public static void main(String[] args) {
Host host = new Host();
Proxy proxy = new Proxy(host);
proxy.Renthouse();
}
}

动态代理

动态代理分为三大类:基于接口(JDK动态代理)、基于类(CGLIB动态代理)、Java字节码实现(Javassist)。

动态代理实现案例

public interface Rent {
void Rent();
}
public class Host implements Rent {
@Override
public void Rent() {
System.out.println("房东有一整套房子出租!!!");
}
}
public class ProxyInvocationHandler implements InvocationHandler {
private Rent rent;
public void setRent(Rent rent) {
this.rent = rent;
}
public Object getProxy() {
return Proxy.newProxyInstance(
this.getClass().getClassLoader(),
rent.getClass().getInterfaces(),
this
);
}
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
return method.invoke(rent, args);
}
}
public class client {
public static void main(String[] args) {
Host host = new Host();
ProxyInvocationHandler pih = new ProxyInvocationHandler();
pih.setRent(host);
Rent proxy = (Rent) pih.getProxy();
proxy.Rent();
}
}

动态代理的好处

  • 可以使真实角色的操作更加纯粹,不去关注一些公共的业务。
  • 公共部分交给代理角色,便于集中管理。
  • 公共部分发生扩展的部分也更容易实现。
  • 一个动态代理类可以代理多个类,只要实现了一个接口即可。
  • 通过以上内容,可以看出动态代理在实际应用中的重要性和优势。

    转载地址:http://venv.baihongyu.com/

    你可能感兴趣的文章
    Mysql 纵表转换为横表
    查看>>
    mysql 编译安装 window篇
    查看>>
    mysql 网络目录_联机目录数据库
    查看>>
    MySQL 聚簇索引&&二级索引&&辅助索引
    查看>>
    Mysql 脏页 脏读 脏数据
    查看>>
    mysql 自增id和UUID做主键性能分析,及最优方案
    查看>>
    Mysql 自定义函数
    查看>>
    mysql 行转列 列转行
    查看>>
    Mysql 表分区
    查看>>
    mysql 表的操作
    查看>>
    mysql 视图,视图更新删除
    查看>>
    MySQL 触发器
    查看>>
    mysql 让所有IP访问数据库
    查看>>
    mysql 记录的增删改查
    查看>>
    MySQL 设置数据库的隔离级别
    查看>>
    MySQL 证明为什么用limit时,offset很大会影响性能
    查看>>
    Mysql 语句操作索引SQL语句
    查看>>
    MySQL 误操作后数据恢复(update,delete忘加where条件)
    查看>>
    MySQL 调优/优化的 101 个建议!
    查看>>
    mysql 转义字符用法_MySql 转义字符的使用说明
    查看>>