代理:就是用代理类实现委托类的一些功能和附加的预处理功能(包括消息过滤,日志等)。
java的代理分为静态代理和动态代理。动态代理又有jdk代理和cglib代理。静态代理分为继承超类代理和接口代理(名称不重要下面会详细介绍)。
在详细介绍之前先介绍一下静态代理和动态代理的区别:
静态代理的时候代理类要实现被代理接口的所有的方法。
动态代理是利用java反射机制,代理类只需要实现InvocationHandler接口即可,无需实现接口所有方法,在扩展和代码优化上有明显优势。
第一:静态代理
在java里只有实现接口或者继承父类才可以实现对其功能,也就是根据这一点静态代理可以分为继承代理和接口代理。
1,继承代理
由于代理的功能一般最好没有实现,否则代理就没有价值了,所以被代理类(委托类)最好是abstract,也就出现了继承代理。
//抽象类
public abstract class UserDao {
public abstract void userAdd();
public abstract void userDelete();
}
//userDao 第一个实现类
public class UserDaoDB2Impl extends UserDao {
@Override
public void userAdd() {
System.out.println("insert user data into db2 datebase!");
}
@Override
public void userDelete() {
System.out.println("delete user data from db2 datebase!");
}
}
//userDao 第二个实现类
public class UserDaoMysqlImpl extends UserDao {
@Override
public void userAdd() {
System.out.println("insert user data into mysql datebase!");
}
@Override
public void userDelete() {
System.out.println("delete user data from mysql datebase!");
}
}
//userDao 代理类
public class UserDaoProxy extends UserDao {
UserDao dao;
public UserDaoProxy(UserDao d){
this.dao=d;
}
@Override
public void userAdd() {
dao.userAdd();
}
@Override
public void userDelete() {
dao.userDelete();
}
}
//测试类
public class UserDaoTest {
/**
* @param args
*/
public static void main(String[] args) {
UserDao mysqldao=new UserDaoMysqlImpl();
UserDao db2dao=new UserDaoDB2Impl();
UserDaoProxy p=new UserDaoProxy(mysqldao);
// UserDaoProxy p=new UserDaoProxy(db2dao);
p.userAdd();
}
}
2,接口代理
这个代理是大家很熟悉的,也是很多人都用过的,就是通过实现接口的方式实现代理,代码如下:
//接口
public interface AdminDao {
public void adminAdd();
public void adminDel();
}
// 第一种DB2 实现类
public class AdminDaoDB2Impl implements AdminDao {
@Override
public void adminAdd() {
System.out.println("insert admin data into DB2 database!");
}
@Override
public void adminDel() {
System.out.println("delete admin data from DB2 database!");
}
}
//第二种oracle 实现类
public class AdminDaoOracleImpl implements AdminDao {
@Override
public void adminAdd() {
System.out.println("insert admin data into oracle database!");
}
@Override
public void adminDel() {
System.out.println("delete admin data from oracle database!");
}
}
//AdminDao 代理类
public class AdminDaoProxy implements AdminDao {
AdminDao dao;
public AdminDaoProxy(AdminDao dao){
this.dao=dao;
}
@Override
public void adminAdd() {
dao.adminAdd();
}
@Override
public void adminDel() {
dao.adminDel();
}
}
// 静态代理测试类
public class AdminTest {
public static void main(String arg[]){
AdminDao db2Dao=new AdminDaoDB2Impl();
AdminDao oracleDao=new AdminDaoOracleImpl();
AdminDaoProxy proxy_1=new AdminDaoProxy(db2Dao);
proxy_1.adminAdd();
AdminDaoProxy proxy_2=new AdminDaoProxy(oracleDao);
proxy_2.adminAdd();
}
}
第二:动态代理
动态代理是利用java反射机制,代理类通过实现InvocationHandler接口来完成对委托类功能的实现,其实里面是jdk对java的部分代码进行了封装,在实现InvocationHandler接口的时候,需要实现invoke方法,而invoke方法里需要传进2个必要参数代理类和Method,其中method里的invoke方法就可以去实现委托类里所有的接口,因为有了这层封装所以代理类不需要在继承或实现被代理类也可以实现代理功能。
//接口
public interface AdminDao {
public void adminAdd();
public void adminDel();
}
//第一种 DB2 实现类
public class AdminDaoDB2Impl implements AdminDao {
@Override
public void adminAdd() {
System.out.println("insert admin data into DB2 database!");
}
@Override
public void adminDel() {
System.out.println("delete admin data from DB2 database!");
}
}
//第二种oracle 实现类
public class AdminDaoOracleImpl implements AdminDao {
@Override
public void adminAdd() {
System.out.println("insert admin data into oracle database!");
}
@Override
public void adminDel() {
System.out.println("delete admin data from oracle database!");
}
}
//动态代理实现类
public class AdminDaoDynamicProxy implements InvocationHandler {
AdminDao admindao;
public AdminDaoDynamicProxy(AdminDao d){
this.admindao=d;
}
@Override
public Object invoke(Object proxy, Method method, Object[] arg2)
throws Throwable {
System.out.println("before---");
Object obj=method.invoke(admindao, arg2);
System.out.println("after----");
return obj;
}
}
//测试类
public class AdminDynamicTest {
public static void main(String[] args) {
AdminDao db2dao=new AdminDaoDB2Impl();
AdminDaoDynamicProxy proxy=new AdminDaoDynamicProxy(db2dao);
//创建动态代理实例(也可以通过另一种方法实现)
AdminDao dao=(AdminDao)Proxy.newProxyInstance(AdminDao.class.getClassLoader(), new Class[]
{AdminDao.class},proxy);
dao.adminAdd();
}
}
备注:代理类里可以实现一些辅助功能,我没有添加,这个需要的时候可以加进去,在此省略。
分享到:
相关推荐
Java提供了两种主要的代理实现方式:静态代理和动态代理。 **静态代理** 静态代理是程序员手动创建代理类并实现与目标对象相同的接口。代理类和目标类都必须实现相同的接口,这样代理类就可以在调用目标对象方法的...
总结来说,Java静态代理和动态代理的主要区别在于: - 静态代理需要手动编写代理类,适用于目标类较少且接口固定的场景。 - 动态代理则通过反射在运行时生成代理类,更加灵活,适用于需要动态地为多个类或接口创建...
Java提供了两种主要的代理实现方式:静态代理和动态代理。 ### 静态代理 静态代理是在编译时就已经确定了代理关系。首先,我们需要定义一个接口,比如`Car`,这个接口描述了汽车的行为: ```java public ...
代理模式通常分为静态代理和动态代理两种类型,这两种代理方式各有特点,适用于不同的场景。 **静态代理** 静态代理是通过程序员手动创建一个代理类来实现的。代理类和真实目标类需要实现相同的接口,以便代理类...
在Java中,代理主要分为静态代理和动态代理。 1. 静态代理: 静态代理是在编译时就已经明确代理类与被代理类关系的一种方式。为了实现静态代理,我们需要手动创建一个代理类,这个代理类通常会实现与被代理类相同的...
代理设计模式分为静态代理和动态代理两种类型。 ### 静态代理 静态代理是在编译时就已经确定了代理关系,代理类和真实类的关系是硬编码在代理类中的。下面我们将详细介绍静态代理的实现方式: 1. **定义接口**:...
Java提供了两种实现代理模式的方式:静态代理和动态代理。 **静态代理** 静态代理是在编译时就已经确定了代理类,通过继承或实现目标接口来创建代理类。以下是一个简单的静态代理实现示例: ```java // 目标接口 ...
Java提供了两种实现代理的主要方式:静态代理和动态代理。 **静态代理** 静态代理是最基础的形式,它需要程序员手动创建一个代理类,该类实现了与目标类相同的接口。代理类持有目标类的引用,并在调用目标类方法...
Java静态代理模式是一种设计模式,它允许我们为一个对象提供一个代理,以便增强或扩展其功能,同时不改变原有对象的代码。在Java中,静态代理是通过在代理类中显式实现目标接口来实现的。下面将详细介绍静态代理模式...
### Java静态代理与动态代理详解 #### 一、代理模式概述 代理模式是软件工程领域中常用的一种设计模式,尤其在Java开发中极为常见。它主要用于控制对某个对象的访问,或者提供额外的功能如日志记录、性能追踪、...
根据实现方式的不同,代理模式可以分为静态代理和动态代理两种。 ### 静态代理 静态代理是在编译时就已经确定了代理关系。我们需要创建一个代理类,该类实现与目标对象相同的接口,并在代理类的方法中调用目标对象...
本篇我们将深入探讨Spring中的静态代理和动态代理,这两种代理模式在实际开发中都有广泛的应用。 首先,让我们理解什么是代理。代理模式是一种设计模式,它为一个对象提供一个代理以控制对这个对象的访问。在Spring...
静态代理和动态代理是两种常见的代理模式,它们在Java中有着广泛的应用,特别是在SpringBoot等框架中。本资源提供了一个简单的Java实现,适用于JDK1.8版本,并经过了验证,对初学者理解设计模式具有指导意义。 静态...
在这个“包含静态代理和动态代理demo代码”的压缩包中,我们可能会看到两种常见的Java代理实现方式的示例:静态代理和动态代理。 首先,我们来详细讲解静态代理。在静态代理中,代理类和真实类(目标类)都是在编译...
本教程将深入探讨静态代理和JDK动态代理的概念、工作原理以及如何实现。 ### 静态代理 静态代理是在编译时就确定了代理类和目标类的关系。代理类和目标类通常都需要实现相同的接口,以便于在代理类中调用目标类的...
Java 动态代理详解(代理模式+静态代理+JDK动态代理+CGLIB动态代理) Java 动态代理是 Java 编程语言中的一种强大工具,广泛应用于 Spring AOP、Hibernate 数据查询、测试框架的后端 mock、RPC 远程调用、Java 注解...