代理设计模式之传统版本(一)
基础准备
实体类
@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
private Integer id;
private String name;
private String hobby;
}
传统版本
service层
public interface UserService {
/**
* 新增用户
*/
int addUser(User user);
/**
* 更新用户
*/
int updateUser(User user);
}
实现类
public class UserServiceImpl implements UserService {
public int addUser(User user) {
System.out.println("开启事务");
System.out.println("正在新增User对象到数据库..."+user);
System.out.println("提交事务");
return 1;
}
public int updateUser(User user) {
System.out.println("开启事务");
System.out.println("正在更新User对象到数据库..."+user);
System.out.println("提交事务");
return 1;
}
}
测试类
public class TestProxy {
@Test
public void test1(){
UserService us=new UserServiceImpl();
int count1 = us.addUser(new User(8989, "老王", "人妻"));
System.out.println(count1>0?"新增成功":"新增失败");
System.out.println("----------------------------------------------------------");
int count2 = us.addUser(new User(8080, "小王", "人妻"));
System.out.println(count1>0?"更新成功":"更新失败");
}
}
运行结果
版本总结
代码耦合度高,冗余
优化-解决代码冗余--封装
公共类
public class Transaction {
public void openTx(){
System.out.println("开启事务");
}
public void closeTx(){
System.out.println("提交事务");
}
}
实现类调用
public class UserServiceImpl implements UserService {
Transaction tx=new Transaction();
public int addUser(User user) {
tx.openTx();
System.out.println("正在新增User对象到数据库..."+user);
tx.closeTx();
return 1;
}
public int updateUser(User user) {
tx.openTx();
System.out.println("正在更新User对象到数据库..."+user);
tx.closeTx();
return 1;
}
}
优化--解耦合
使用静态代理
静态代理
目标类
public class UserServiceImpl implements UserService {
public int addUser(User user) {
System.out.println("正在新增User对象到数据库..."+user);
return 1;
}
public int updateUser(User user) {
System.out.println("正在更新User对象到数据库..."+user);
return 1;
}
}
代理类
public class UserServiceImplProxy implements UserService {
//代理类 代理的是真实类 目标
UserService us=new UserServiceImpl();
//事务
Transaction tx=new Transaction();
public int addUser(User user) {
tx.openTx();
//调用目标对象的真实方法
int count = us.addUser(user);
tx.closeTx();
return count;
}
public int updateUser(User user) {
tx.openTx();
//调用目标对象的真实方法
int count = us.updateUser(user);
tx.closeTx();
return count;
}
}
测试类
public class TestProxy {
@Test
public void test1(){
// us 本质是代理类对象
// 为什么可以用接口接收? 因为代理类 和 目标类 实现了同一个接口!
UserService us=new UserServiceImplProxy();
// addUser 是代理类对象的方法
int count1 = us.addUser(new User(8989, "老王", "人妻"));
System.out.println(count1>0?"新增成功":"新增失败");
System.out.println("----------------------------------------------------------");
int count2 = us.addUser(new User(8080, "小王", "人妻"));
System.out.println(count1>0?"更新成功":"更新失败");
}
}
版本总结
手动创建代理类,接口方法变化,是实现类需要重写
别说差点,差点就是永远
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理