为什么我的Java代码越来越“胖”?浅析职责单一原则

简介: 为什么我的Java代码越来越“胖”?浅析职责单一原则

作为一名Java开发者,你是否曾面对过一个几千行的“上帝类”,它无所不能,却也难以维护和测试?这种代码“肥胖症”的根源,往往在于对单一职责原则 的忽视。

什么是单一职责原则?

单一职责原则是SOLID原则中的第一个“S”。它的核心定义是:一个类应该只有一个引起变化的原因。 简单来说,一个类只负责一件事,并且将这件事做好。

一个反例:臃肿的订单处理器

想象一下我们有一个 OrderProcessor 类:

public class OrderProcessor {
   
    public void process(Order order) {
   
        // 1. 验证订单
        if (!order.isValid()) {
   
            throw new InvalidOrderException();
        }

        // 2. 计算税费(复杂的业务逻辑)
        BigDecimal tax = calculateTax(order);

        // 3. 保存到数据库
        saveToDatabase(order);

        // 4. 发送邮件通知
        sendEmailNotification(order);

        // 5. 生成发票PDF
        generateInvoicePdf(order);
    }

    // ... 上述每个步骤对应一个私有方法
}

这个类看似功能完整,但它承担了太多职责:验证、计税、持久化、通知、文件生成。任何一方面的需求变更(比如邮件模板改了,或者计税规则变了)都需要修改这个类,这违背了SRP。

重构:让类“瘦”下来

我们可以将上述职责拆分到不同的类中:

  • OrderValidator:专门负责验证。
  • TaxCalculator:专门负责计税。
  • OrderRepository:专门负责数据持久化。
  • NotificationService:专门负责发送通知。
  • InvoiceGenerator:专门负责生成发票。

重构后的 OrderProcessor

public class OrderProcessor {
   
    private OrderValidator validator;
    private TaxCalculator taxCalculator;
    private OrderRepository repository;
    private NotificationService notifier;
    private InvoiceGenerator invoiceGenerator;

    // 通过构造函数依赖注入
    public OrderProcessor(...) {
    ... }

    public void process(Order order) {
   
        validator.validate(order);
        taxCalculator.calculate(order);
        repository.save(order);
        notifier.notifyCustomer(order);
        invoiceGenerator.generate(order);
    }
}

这样做的好处:

  1. 高内聚:每个类都专注于自己的领域,逻辑更清晰。
  2. 低耦合:修改邮件通知逻辑不会影响到计税或数据库模块。
  3. 易于测试:你可以轻松地Mock NotificationService 来测试 OrderProcessor,而不必真正发送邮件。
  4. 便于协作:团队成员可以并行开发不同的模块,而不会产生代码冲突。

总结

单一职责原则是构建健壮、灵活、可维护Java应用的基石。下次当你觉得一个类变得难以理解或修改时,不妨问问自己:“这个类承担的责任是否太多了?” 通过持续重构,让你的代码保持“苗条”与健康。

目录
相关文章
|
3月前
|
存储 分布式计算 数据库
ETL vs ELT:到底谁更牛?别被名字骗了,这俩是两种世界观
ETL vs ELT:到底谁更牛?别被名字骗了,这俩是两种世界观
166 12
|
3月前
|
消息中间件 存储 关系型数据库
消息队列四大核心消息类型深度解析:普通、顺序、事务、定时消息原理与实战
本文深入剖析了分布式系统中消息队列的四大核心消息类型。普通消息作为基础模型实现异步通信;顺序消息通过分区有序机制保证关键业务流程的顺序性;事务消息基于两阶段提交解决分布式事务问题;定时消息则支持延迟任务执行。文章从原理、实现到应用场景,结合RocketMQ实例代码(包括事务消息与MySQL的整合)进行了全面讲解,并提供了选型对比建议。这四种消息类型各具特点,开发者应根据业务需求在解耦、顺序保证、事务一致性和延迟执行等维度进行合理选择,以构建高性能、高可用的分布式系统。
310 1
|
SQL 前端开发 搜索推荐
淘天业务技术2023年度热门文章盘点
淘天业务技术2023年度热门文章盘点
403 4
|
3月前
|
安全 Java 编译器
锁的进化:深入理解Java中的锁粗化与锁消除
锁的进化:深入理解Java中的锁粗化与锁消除
229 114
|
3月前
|
安全 Java 程序员
《Optional:告别空指针的“优雅之道”与“使用陷阱”》
《Optional:告别空指针的“优雅之道”与“使用陷阱”》
209 114
|
3月前
|
安全 IDE Java
别让“配置”成为你系统的无声刺客:拥抱Type-Safe的配置管理
别让“配置”成为你系统的无声刺客:拥抱Type-Safe的配置管理
211 113
|
3月前
|
运维 监控 应用服务中间件
藏在Nginx配置里的“坑”:一个`if`指令引发的深夜告警
藏在Nginx配置里的“坑”:一个`if`指令引发的深夜告警
190 90
|
3月前
|
前端开发 JavaScript API
什么是 Headless UI?
什么是 Headless UI?
421 115
|
2月前
|
安全 Java
告别繁琐Case:Java 17的Switch表达式让代码更优雅
告别繁琐Case:Java 17的Switch表达式让代码更优雅
|
2月前
|
缓存 安全 Java
探索并发编程中ConcurrentHashMap的使用
综上所述,ConcurrentHashMap是Java并发编程中不可或缺的一部分,它通过与操作系统、JVM及硬件特性紧密结合,为开发高效且线程安全的并发应用程序提供了强大的数据结构支持。掌握ConcurrentHashMap的使用是实现高性能并发程序的关键步骤之一。
200 117