首页 > 其他分享 >学习高校课程-软件设计模式-软件设计原则(lec2)

学习高校课程-软件设计模式-软件设计原则(lec2)

时间:2024-09-13 20:05:00浏览次数:12  
标签:超类 level 软件设计 子类 高校 subclass classes lec2 class

Feature of Good Design (1) 优秀设计的特点(一)

Code reuse 代码复用

– Challenge: tight coupling between components, dependencies on concrete classes instead of interfaces, hardcoded operations
– Solution: design patterns
– 挑战:组件之间的紧密耦合、对具体类而不是接口的依赖、硬编码操作
– 解决方案:设计模式
• However, sometimes making components more complicated
然而,有时会使组件变得更加复杂
– Three levels of reuse: a piece of wisdom from Erich Gamma
– 三个层次的重用:Erich Gamma 的智慧
• Lowest: classes
最低:类
• Highest: frameworks
最高:框架
• Middle level: design patterns
中层:设计模式

Feature of Good Design (2) 优秀设计的特点(二)

Extensibility 可扩展性

Change is the only constant thing in a programmer’s life
– 变化是程序员一生中唯一不变的事情
• We understand the problem better once we start to solve it
一旦我们开始解决问题,我们就会更好地理解问题
• Something beyond your control has changed
你无法控制的事情已经发生了变化
• Objectives/requirements have changed
目标/要求已改变
– Prepare for possible future changes when designing an architecture
– 设计结构时为未来可能发生的变化做好准备

Good Design Principles (1) 良好的设计原则(1)

Encapsulate what varies 封装不同的内容

– Identify the aspects of your application that vary, and separate them from what stays the same
– 识别应用程序中不同的方面,并将它们与保持不变的部分区分开来
– Main goal: minimize the effect caused by changes
– 主要目标:最小化变化造成的影响
– Isolating program parts that vary in independent modules, protecting the rest
-隔离独立模块中不同的程序部分,保护其余部分
– Encapsulation on a method level
– 方法级别的封装
– Encapsulation on a class level
– 类级别的封装

Good Design Principles (2) 良好的设计原则(2)

Program to an interface, not an implementation 对接口编程,而不是实现

– In other words, depend on abstractions, not on concrete classes
– 换句话说,依赖于抽象,而不是具体的类
– The design is flexible enough if you can easily extend it without breaking existing code
– 如果您可以轻松地扩展它而无需破坏现有代码,那么该设计就足够灵活
– A possible approach

  1. Determine what exactly one object needs from the other: which methods does it execute?
    确定一个对象到底需要另一个对象什么:它执行哪些方法?
  2. Describe these methods in a new interface or abstract class.
    在新的接口或抽象类中描述这些方法。
  3. Make the class that is a dependency implement this interface.
    使作为依赖项的类实现此接口。
  4. Make the second class dependent on this interface rather than on the
    concrete class.
    使第二个类依赖于该接口而不是具体的类。

Good Design Principles (3) 良好的设计原则(3)

Favor composition over inheritance 优先考虑组合而不是继承

– Challenge of inheritance
– 继承的挑战
• A subclass can’t reduce the interface of the superclass
子类不能减少超类的接口
• When overriding methods you need to make sure that the new behavior is compatible with the base one
重写方法时,您需要确保新行为与基本行为兼容
• Inheritance breaks encapsulation of the superclass
继承破坏了超类的封装
• Subclasses are tightly coupled to superclasses
子类与超类紧密耦合
• Trying to reuse code through inheritance can lead to creating parallel inheritance hierarchies
尝试通过继承重用代码可能会导致创建并行继承层次结构

SOLID Principles

SOLID 1: Single Responsibility Principle 单一职责原则

A class should have just one reason to change
一个类应该只有一个改变的理由
– Try to make every class responsible for a single part of functionality,and make that responsibility entirely encapsulated
– 尝试让每个类负责一部分功能,并完全封装该职责
• Main goal: reducing complexity, and reducing risks
主要目标:降低复杂性并降低风险

SOLID 2: Open/Closed Principle 开闭原理

  • Classes should be open for extension but closed for modification
    类应该对扩展开放,但对修改关闭
    – Keep existing code from breaking when implementing new features
    – 在实现新功能时防止现有代码被破坏
  • A class is open if it can be extended by subclasses
    如果一个类可以通过子类扩展,则该类是开放的
  • A class is closed if it is 100% ready to be used by others
    如果一个类 100% 可供其他人使用,则该类已关闭
  • A class can be both open (for extension) and closed (for modification) at the same time
    一个类可以同时开放(用于扩展)和封闭(用于修改)
    – Not necessary to be applied for all changes
    – 无需应用所有变更

SOLID 3:Liskov Substitution Principle 里氏替换原理

  • When extending a class, ensure the capability of passing objects of the subclass in place of objects of the parent class without breaking the client code
    扩展类时,保证能够通过子类的对象代替父类的对象,而不破坏客户端代码

  • The subclass should remain compatible with the behavior of the superclass
    子类应该与超类的行为保持兼容
    – When overriding a method, extend the base behavior rather than replacing it with something else entirely
    重写方法时,扩展基本行为而不是完全用其他东西替换它

  • Especially critical when developing libraries and frameworks
    在开发库和框架时尤其重要

  • A set of checks
    一组检查

    • (a) Parameter types in a method of a subclass should match or be more abstract than parameter types in the method of the superclass.
      子类方法中的参数类型应与超类方法中的参数类型匹配或更抽象。
    • (b) The return type in a method of a subclass should match or be a subtype of the return type in the method of the superclass.
      子类方法中的返回类型应该与超类方法中的返回类型匹配或者是其子类型。
    • (c) Types of exceptions should match or be subtypes of the ones that the base method is already able to throw.
      异常类型应该与基方法已经能够抛出的异常类型匹配或者是其子类型。
    • (d) A subclass shouldn’t strengthen pre-conditions.
      子类不应强化先决条件
    • (e) A subclass shouldn’t weaken post-conditions.
      子类不应削弱后置条件
    • (f) Invariants of a superclass must be preserved (least formal rule of all)
      必须保留超类的不变量(至少所有正式规则)
    • (g) A subclass shouldn’t change values of private fields of the superclass.
      子类不应更改超类的私有字段的值。

SOLID 4: Interface Segregation Principle 接口隔离原则

Clients shouldn’t be forced to depend on methods they do not use
不应强迫实现代码依赖他们不使用的方法
– Make interfaces narrow enough that client classes don’t have to implement
behaviors they don’t need
– 使接口足够窄,以便实现代码类不必实现它们不需要的行为
– Break down “fat” interfaces into more granular and specific ones
– 将“胖”接口分解为更细粒度和更具体的接口

SOLID 5: Dependency Inversion Principle 依赖倒置原则

  • High-level classes shouldn’t depend on low-level classes, and both should depend on abstractions
    高级别的类不应该依赖于低级别的类,并且两者都应该依赖于抽象
  • Problem: business logic classes tend to become dependent on primitive low-level classes
    问题:业务逻辑类往往会依赖于原始的低级类
  • Suggestion: changing the direction of dependency
    建议:改变依赖方向
  • Approach
    • Describe interfaces for low-level operations that high-level classes rely on, preferably in business terms
      描述高级类所依赖的低级操作的接口,最好用业务术语
    • Make high-level classes dependent on the interfaces, resulting in a softer dependency
      使高级类依赖于接口,从而产生更软的依赖关系
    • Low-level classes implement the interfaces, dependent on the business logic level
      低级类实现接口,依赖于业务逻辑级别

标签:超类,level,软件设计,子类,高校,subclass,classes,lec2,class
From: https://www.cnblogs.com/Mephostopheles/p/18412406

相关文章

  • 学习高校课程-软件设计模式-OOP 和 UML 类图 OOP 与 Java(lec1)
    Lecture1:OOPandUMLClassDiagramsOOPwithJavaOOP和UML类图OOP与JavaObject-OrientedProgramming面向对象编程ClassHierarchies类层次结构Superclassandsubclass超类和子类PillarsofObject-OrientedProgramming面向对象编程的支柱Abstraction–M......
  • 【系统分析师】-软件设计
    目录1、概要设计1)层次图(H图)2)HIPO图2、详细设计1)流程图2)盒图(N-S图)3)PAD问题分析图4)PDL伪代码图3、软件设计过程4、软件设计活动4.1、数据设计4.2、软件结构设计4.3、人机界面设计(接口设计)4.4、过程设计5、结构化设计5.1、抽象化5.2、自顶向下5.3、信息隐藏......
  • 学习高校课程-软件设计模式-简介(lec0)
    Lecture0IntroductiontotheCourseWhatareDesignPatternsTypicalsolutionstocommonlyoccurringproblemsinsoftwaredesign,likepre-madeblueprints.Creationalpatterns,structuralpatterns,andbehavioralpatterns软件设计中常见问题的典型解决方案,例如......
  • 软件设计模式-单例模式
    单例模式(SingletonPattern)是创建型设计模式的一种,旨在确保一个类在整个应用程序运行期间只有一个实例,并提供全局访问点来获取该实例。这种模式对于那些希望在整个系统中共享唯一对象的场景非常有用,比如数据库连接、日志系统、配置管理器等。单例模式的核心要点唯一实例:类只能有......
  • 软件设计模式-生成器模式
    生成器模式的结构生成器(Builder):提供构建产品各部分的方法,一般是一步一步构建复杂对象的各个部分。具体生成器(ConcreteBuilder):实现生成器接口,构建和装配具体的产品部件。产品(Product):最终生成的复杂对象。指挥者(Director):负责安排构建步骤,控制生成器构建对象的过程(可选)。客户端......
  • 【软件设计师真题】下午题第二大题---数据库设计
    系列文章目录1.【软考之软件设计师】PPT课件2.【软考之软件设计师】学习笔记3.【软件设计师真题】下午题第一大题—数据流图设计4.【软件设计师真题】下午题第二大题—数据库设计5.【软件设计师真题】下午题第三大题—UML分析与设计6.【软件设计师真题】下午题......
  • 软件设计师中级(程序语言)
    目录一、程序设计语言概述1.低级语言与高级语言2.程序设计语言发展概述3.程序设计语言杂论4.程序设计语言的基本成分5.函数二、汇编、编译、解释1.汇编程序基本原理2.编译程序基本原理3.解释程序基本原理4.编译与解释比较三、文法分析1.正规式2.有限自动机3.上......
  • 高校毕业生就业大数据分析系统的设计与实现毕业设计源码
    博主介绍:✌专注于VUE,小程序,安卓,Java,python,物联网专业,有17年开发经验,长年从事毕业指导,项目实战✌选取一个适合的毕业设计题目很重要。✌关注✌私信我✌具体的问题,我会尽力帮助你。目录研究目的研究意义国外研究现状分析国内研究现状分析研究内容需求分析可行性分析......
  • SSM高校图书馆座位的智能化管理系统小程序-毕业设计源码15796
    摘要信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对高校图书馆座位的智能化管理系统小程序等问题,对高校图书馆座位的智能化管理系统小程序进行研......
  • springboot高校学生请假管理系统-计算机毕业设计源码38439
    摘要本文针对高校学生考勤等问题,对其进行研究分析,然后开发设计出高校学生请假管理系统以解决问题。高校学生请假管理系统主要功能模块包括:请假信息管理、请假通知管理、审批通知管理、假期安排管理、审批反馈管理、请假分析管理、通知公告管理等,系统功能设计采取MySQL作为后......