【设计】OOA、OOD、OOP

news/2025/3/26 16:36:08/

这三者都是 OO(Object-Oriented)领域的思想。
一般我们我们接到产品经理的需求后,开发阶段分这样几个步骤:

  1. 可行性预研阶段,此阶段评估需求是否合理,能否实现;
  2. OOA阶段,此阶段分析用例,定义领域模型;
  3. OOD阶段,此阶段定义类图,类之间的交互图(时序图等);
  4. OOP阶段,根据OOD设计的类图,类之间的交互图输出代码。

那么除了可行性预研阶段,其他三个阶段都是需求开发的重要步骤。
1669638514559-af822c23-b9db-4d80-8696-f32b865f1494.png

OOA

OOA,Object-Oriented Analysis,面向对象分析。此过程是把现实的需求转义为领域模型(Domain Model)问题,以及输出领域模型(Domain Model)。
OOA 的主要流程也有既定的一些步骤:

  1. 根据需求输出用例,用例为所有的使用场景,主要为用户与应用的交互
  2. 根据用例输出领域模型(Domian Model),领域模型(Domain Model)也就是常说的业务逻辑。这时候会输出概念类,概念类的交互关系,这些概念类一般是系统的直接映射。

在 OOA 中,考验的是程序员的分析能力。拥有 OOA 能力的人,能抽象出更全面,更能准确复用的系统设计。

OOD

OOD 全拼为 Object-Oriented Design,面向对象设计。
此过程是把我们的领域模型转为逻辑架构,类图,类之间的关系。 如何分层,如何分包,如何保证高内聚低耦合都是这部分要考虑的问题。这个阶段输出类图,时序图,模块图等。

OOP

OOP 全程为 Object-Oriented Programming,面向对象编程。是将 OOD 的设计结果转为面向对象编码的过程。
在这一个步骤中,我们要非常注重 OOP 的思想。
OOP 思想指的是面向对象编程,面向对象强调对象的抽象,还有“封装”、“继承”、“多态”,相比面向过程该思想专注于通过对象的一些方法去解决问题,不同的功能可能由不同的对象来负责解决。
面向对象思想中,主要需要注意下面这些原则:

  • **开闭原则(Open Close Principle)**开闭原则的意思是:对扩展开放,对修改关闭。
  • **里氏代换原则(Liskov Substitution Principle)**任何基类可以出现的地方,子类一定可以出现。
  • **依赖倒转原则(Dependence Inversion Principle)**针对接口编程,依赖于抽象而不依赖于具体。
  • **接口隔离原则(Interface Segregation Principle)**使用多个隔离的接口,比使用单个接口要好。
  • **迪米特法则,又称最少知道原则(Demeter Principle)**一个实体应当尽量少地与其他实体之间发生相互作用,使得系统功能模块相对独立。
  • **合成复用原则(Composite Reuse Principle)**尽量使用合成/聚合的方式,而不是使用继承。

总结

OOA,OOD,OOP 是针对现实的需求最终输出产品过程。在现实中 OOA,OOD 并没有显著的区分。OOA,OOD,OOP 有时是不断的交替进行。
对于现在的软件开发中,大部分迅速敏捷至极的项目,基本上是不会输出相关的开发设计图资源的,而是直接进入到 OOP 的阶段。直接进入 OOP 阶段,缺乏足够的 OOA 以及 OOD 过程,那么就会对 OOP 阶段的代码质量造成影响。
这里也并不是说有了 OOA 和 OOD,系统的质量就一定好;而是有了 OOA 和 OOD,可以输出更符合标注和规范的 OOP 代码,完成更出色的系统设计。

参考文档:

https://juejin.cn/post/6890063876163911693


http://www.ppmy.cn/news/494098.html

相关文章

docker详细介绍

关于 Docker 是什么,有个著名的隐喻:集装箱。但是它却起了个“码头工人”(docker 的英文翻译)的名字。 这无疑给使用者很多暗示:“快来用吧!用了 Docker,就像世界出现了集装箱,这样你…

什么是算法

有人说程序算法数据结构,虽说这样的认为有失偏颇,一个程序决定的东西实在太多,但某些方面也说明了算法是很重要的(数据结构承上启下,最终也是要为算法服务)。 算法是用来解决问题的,要理解什么是…

三子棋小游戏【C语言】

目录 前言 一、基本实现逻辑 二、实现步骤 1.实现进入游戏后的选择菜单——》这个实现起来较为容易,我们约定为:1是玩游戏, 0 是退出游戏! 2.要玩完了一局后接着玩,很容易想到要用循环。 3.采用多文件编程---》我…

【记录】凯酷84说明书

凯酷84按键说明 键位功能FNF1我的电脑FNF2浏览器FNF3计算器FNF4音乐播放器FNF5上一曲FNF6下一曲FNF7播放 / 暂停FNF8停止FNF9静音FNF10减小音量FNF11加大音量FNF12锁WIN键FNPrtSc(截图键)切换副键盘数字区FNPauseScroll键FNDEllnsert键

用JavaScript实现网红太空人表盘(绝对详细、绝对原创),附源码下载

引言:网上最近太空人表盘很火,之前看到有个兄弟用svg写的,但是我也不会这个啊,我就琢磨着用canvas写了一个,效果感觉还不错,拿出来大家唠唠! 效果图: 思路 分两个画布来绘制&#x…

爱普生Epson打印机废墨垫清零软件适用于L3110L3118L3119L1118免费

现在,越来越多的人开始使用打印机进行办公和生活中的印刷工作。然而,随着使用时间的增加,打印机的废墨垫会逐渐填满,这会导致打印机无法正常工作。这时,我们就需要使用爱普生废墨垫清零软件来解决这一问题。 解决废墨…

docker-compose启动opengauss数据库——华为“自研”数据库

文章目录 1. 启动数据库2. 登录2.1 本地登录2.2 远程登录 1. 启动数据库 yml文件 创建opengauss目录,里边创建docker-compose.yml文件内容如下: 华为开源数据库,默认5432端口,是不是很熟悉,疑似又是个套壳子的事件。果…

Pandas-pd.concat函数知识点总结

前言 本文是该专栏的第33篇,后面会持续分享python数据分析的干货知识,记得关注。 在处理数据分析的需求时,或多或少会需要你将多个数据合并,而数据合并在数据分析的项目中是非常常见的。 对于数据合并,需求不一样,合并数据的方式也会不一样。有常见的拼接合并,也有类似…