软件构造学习笔记(9) --Construction for Change

学习笔记

1. 软件维护与演化
  • 定义: 软件维护是软件交付后对其进行修改的过程,目的在于纠正错误、改善性能或其他属性。
  • 重要性: 维护是软件开发中最具挑战性的工作之一,因为它涉及到软件开发的各个阶段。
  • 类型:
    • 纠错性维护(25%)
    • 适应性维护(21%)
    • 完善性维护(50%)
    • 预防性维护(4%)
2. 可维护性度量
  • 可维护性: 软件系统或组件更正错误、改进性能或适应环境变化的容易程度。
  • 度量指标:
    • 圈复杂度(Cyclomatic Complexity)
    • 代码行数(Lines of Code)
    • Halstead Volume
    • 可维护性指数(Maintainability Index, MI)
    • 继承深度(Depth of Inheritance)
    • 类间耦合度(Class Coupling)
    • 单元测试覆盖度(Unit test coverage)
3. 模块化设计与原则
  • 模块化编程: 将程序功能划分为独立、可互换的模块。
  • 设计目标: 高内聚、低耦合。
  • 评价标准:
    • 可分解性(Decompose)
    • 可组合性(Composability)
    • 可理解性(Understandability)
    • 可持续性(Continuity)
    • 保护性(Protection)
4. 面向对象设计原则SOLID
  • 单一责任原则(SRP): 一个类应该只有一个引起变化的原因。
  • 开放-封闭原则(OCP): 类应该对扩展开放,对修改封闭。
  • 里氏替换原则(LSP): 子类型必须能够替换其基类型。
  • 依赖倒置原则(DIP): 高层模块不应该依赖低层模块,两者都应该依赖于抽象。
  • 接口隔离原则(ISP): 客户端不应该依赖于它们不使用的方法。
5. 基于语法的构造技术
  • 语法: 用于描述字符串或字符序列的规则集合。
  • 解析器: 将输入文本转换为解析树的程序。
  • 正则表达式: 用于字符串处理任务的工具,可以简化为正则语法。

心得体会

通过学习,我深刻认识到软件维护和演化的重要性。软件不是一次性的产品,而是需要持续改进和适应变化的活体。可维护性是衡量软件质量的关键指标,它直接影响到软件生命周期内的成本和风险。

模块化设计原则和面向对象设计原则SOLID为我提供了设计高质量软件的理论基础。这些原则指导我如何创建灵活、可扩展且易于维护的系统。特别是单一责任原则和开放-封闭原则,它们帮助我构建出松耦合、高内聚的代码结构。

基于语法的构造技术让我了解到如何使用形式化的方法来处理文本数据。语法和解析器的概念为我提供了一种强大的方式来解析和验证输入数据,确保它们符合预期的格式。正则表达式虽然功能强大,但其可读性和易维护性相对较差,因此在实际应用中需要谨慎使用。

  • 10
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值