如何去构建高效软件:耦合、内聚与结构化策略(软件设计师笔记)

news2024/10/5 5:40:57

😀前言
随着软件开发变得越来越复杂,如何有效、有序地构建和维护这些复杂系统成为了每一个开发者和设计师所面临的挑战。对于这一挑战,结构化开发方法为我们提供了答案。这一方法不仅帮助我们理解如何将大型系统分解为小模块,还为我们展示了如何通过明确的设计原则和工具(如数据流图和数据字典)确保这些模块的有效协同工作。本章将详细介绍结构化开发方法的核心概念、重点关注模块独立性的两大维度:耦合与内聚,并探讨如何通过系统结构设计原则,数据流图和数据字典来实现高效的软件设计。

🏠个人主页:尘觉主页
在这里插入图片描述

🧑个人简介:大家好,我是尘觉,希望我的文章可以帮助到大家,您的满意是我的动力😉😉

在csdn获奖荣誉: 🏆csdn城市之星2名
⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ 💓Java全栈群星计划top前5
⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ 🤗 端午大礼包获得者
⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ 🥰阿里云专家博主
⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ ⁣⁣⁣⁣ 😉亚马逊DyamoDB结营

💕欢迎大家:这里是CSDN,我总结知识的地方,欢迎来到我的博客,感谢大家的观看🥰
如果文章有什么需要改进的地方还请大佬不吝赐教 先在次感谢啦😊

文章目录

    • 第六章 结构化开发方法
      • 模块独立
        • 🔺耦合
        • 🔺内聚
      • 🔺系统结构设计原则
      • 数据流图
      • 数据字典
        • 加工逻辑的描述
    • 😄总结

第六章 结构化开发方法

模块独立

🔺耦合

耦合是模块之间的相对独立性(互相连接的紧密程度)的度量。耦合取决于各个模块之间接口的复杂程度、调用模块的方式以及通过接口的信息类型等。

  • 无直接耦合:指两个模块之间没有直接的关系,属于不同模块。
  • 数据耦合:指两个模块之间有调用关系,传递的是简单的数据值。
  • 标记耦合:指两个模块之间传递的是数据结构。
  • 控制耦合:指一个模块调用另一个模块时,传递的是控制变量。
  • 外部耦合:模块间通过软件之外的环境联结。
  • 公共耦合:通过一个公共数据环境相互作用。
  • 内容耦合:当一个模块直接使用另一个模块的内部数据,或通过非正常入口转入另一个模块内部。
🔺内聚

内聚是对一个模块内部各个元素彼此结合的紧密程度的度量。

  • 偶然内聚(巧合内聚):各处理元素之间没有任何联系
  • 逻辑内聚:模块内执行若干个逻辑上相似的功能。
  • 时间内聚:把需要同时执行的动作组合在一起。
  • 过程内聚:指定的过程执行。
  • 通信内聚:模块内的所有处理元素都在同一个数据结构上操作。
  • 顺序内聚:指一个模块中的各个处理元素都密切相关于同一功能且必须顺序执行。
  • 功能内聚:最强的内聚,指模块内的所有元素共同作用完成一个功能,缺一不可。

总结:耦合性和内聚性是模块独立性的两个定性标准,在将软件系统划分模块时,应尽量做到高内聚、低耦合,提高模块的独立性。

🔺系统结构设计原则

  1. 分解-协调原则
  2. 自顶向下的原则
  3. 信息隐蔽、抽象的原则
  4. 一致性原则:统一的规范、统一的标准和统一的文件模式。
  5. 明确性原则:功能明确、接口明确、消除多重功能和无用接口、避免病态连接、降低接口复杂度。
  6. 模块之间的耦合尽可能小,模块的内聚度尽可能高。(高内聚、低耦合)
  7. 模块的扇入系数和扇出系数要合理。(扇入扇出适中)
  8. 模块的规模适当。
  9. 模块的作用范围应该在其控制范围之内。

数据流图

数据流图(DFD)是一种图形工具,用于表示系统中数据的流动和处理。它使用符号来表示数据流、处理步骤(或称为“加工”)和数据存储。

数据字典

数据字典是一个详细的、组织良好的“数据仓库”,其中列出了在数据流图中使用的所有数据元素的定义和特性。

数据字典确保数据的一致性和准确性,并为分析师、开发人员和测试人员提供了一个共同的参考框架。

加工逻辑的描述

描述加工逻辑的方法是为了确保对数据流图中的加工有一个清晰、明确的理解。这通常包括:

  • 结构化语言:类似于伪代码,用来描述加工的逻辑步骤。
  • 判定表:是一个二维表,用于表示决策的逻辑。
  • 判定树:是一个图形表示,用于表示决策的逻辑。

总之,结构化开发方法为软件开发提供了一个清晰的框架和方法,使得系统更易于设计、实施和维护。

😄总结

本章通过深入探讨结构化开发方法,为我们揭示了软件系统结构的核心原则和工具。我们学习了耦合和内聚这两个关键概念,并了解了如何通过确保高内聚、低耦合来提高模块的独立性。此外,我们还介绍了数据流图和数据字典,这两个工具能够帮助我们更好地描述和管理软件系统中的数据流和逻辑。总的来说,结构化开发方法为我们提供了一个清晰、有条理的方法,帮助我们有效地构建和维护复杂的软件系统。

😁热门专栏推荐
想学习vue的可以看看这个

java基础合集

数据库合集

redis合集

nginx合集

linux合集

手写机制

微服务组件

spring_尘觉

springMVC

mybits

等等等还有许多优秀的合集在主页等着大家的光顾感谢大家的支持

🤔欢迎大家加入我的社区 尘觉社区

文章到这里就结束了,如果有什么疑问的地方请指出,诸佬们一起来评论区一起讨论😁
希望能和诸佬们一起努力,今后我们一起观看感谢您的阅读🍻
如果帮助到您不妨3连支持一下,创造不易您们的支持是我的动力🤞

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1041719.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

浅谈智能型电动机保护器在孟加拉水泥厂的应用

摘要:电动机设备是水泥企业中应用较广泛的动力装置,而水泥生产企业属于能耗高、污染大又需要设备连续不间断工作的行业,电动机作为水泥行业设备的动力来源,其安全、稳定可靠的运转对水泥行业的平稳生产起着至关重要的作用。 Abst…

Linux驱动开发笔记

疑问 file_operation中每个操作函数的形参中inode的作用 设备树中compatible属性中厂商和型号如何填写 file_operation定义了Linux内核驱动的所有的操作函数,每个操作函数与一个系统调用对应,对于字符设备来说,常用的函数有:lls…

【Vue.js】使用Element中的Mock.js搭建首页导航左侧菜单---【超高级教学】

一,Mock.js 1.1 认识Mock.js Mock.js是一个用于前端开发中生成随机数据、模拟接口响应的 JavaScript 库。模拟数据的生成器,用来帮助前端调试开发、进行前后端的原型分离以及用来提高自动化测试效率 总结来说,Element中的Mock.js是一个用于…

数据安全态势管理:什么是事实,什么是虚构?

考虑到组织存储大量数据的日益复杂的云环境,数据安全态势管理 ( DSPM )的兴起并不令人意外。使组织能够全面了解云数据资产和敏感数据的安全状况的流程对于当今的安全团队来说非常有价值。 尽管 DSPM 的重要性日益凸显,但人们对于它能为企业做什么和不能…

Qt中额外复制新类到工程中出现无法解析的外部符号

无法解析的外部符号 “public: virtual struct QMetaObject const * __cdecl FormCloudFilter::metaObject(v 错误原因:在C项目中,新添加了类之后,编译出现错误,原因是我们新添加的类未被Qt编译成moc文件。 解决方法: …

SpringCloud 学习(三)Ribbon 和 Feign

4. Netflix.Ribbon 4.1 简介 (1) 概念 Spring Cloud Ribbon 是基于 Netflix Ribbon 实现的一套客户端负载均衡工具。 (2) 负载均衡(LB:LoadBalance)和集群架构 应用集群:将同一应用部署到多台机器上,组成处理集群&…

文档升级 | iTOP-RK3568开发板ADB工具的安装和使用

iTOP -RK3568开发板使用手册更新,后续资料会不断更新,不断完善,帮助用户快速入门,大大提升研发速度。 《iTOP-3568开发板ADB使用手册》进行了文档升级,对ADB工具的安装和使用进行了更全面的步骤介绍。 第1章 安装adb工…

git revert 撤销之前的提交

git revert 用来撤销之前的提交,它会生成一个新的 commit id 。 输入 git revert --help 可以看到帮忙信息。 git revert commitID 不编辑新的 commit 说明 git log 找到需要撤销的 commitID , 然后执行 git revert commitID ,会提示如下…

DataGrip初始化设置

DataGrip初始化设置 自定义设置 具体配置项 Customize —> Allsettins… 外观 退出IDE之前无需确认 启动IDE自动打开之前的项目 Appearance & Behavior —> System Settings —> Confirm before exiting the IDE Appearance & Behavior —> System Settin…

写一个Chrome浏览器插件(manifest v3)

目录 1、创建manifest.json 文件 2、开始写popup页面以及对应的逻辑。 2.1 popup 页面 2.2 后台运行 background.js 2.3 content.js 2.4 popup页面的js文件 3、chrome 浏览器加载本项目 4、参考文档 1、创建manifest.json 文件 首先需要在项目的根目录下创建manifes…

深入剖析Redis系列- Redis数据结构之哈希

1.11.5哈希类型(hash) Redis的hash 是一个string类型的key和value的映射表,这里的value是一系列的键值对,hash特别适合用于存储对象。 哈希类型的数据操作总的思想是通过key和field操作value,key是数据标识,field是域,…

基于SSM+Vue的舞蹈网站

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用Vue技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

大二上Redis学习笔记

redis非关系型数据库NOSQL,用c语言编写的,基于内存的数据库,每秒支持十几万的读写操作,性能远超数据库,还支持集群、分布式、主从同步等配置。 Redis基本功能 1 发布订阅系统 2 地图信息分析 3 计时器和计数器 redis运行的图形界…

【腾讯云TDSQL-C Serverless 产品体验】使用 Python向TDSQL-C添加读取数据实现词云图

关于TDSQL-C Serverless介绍 TDSQL-C 是腾讯云自主研发的新一代云原生关系型数据库。 它融合了传统数据库、云计算和新硬件技术的优势,100%兼容 MySQL,为用户提供具有极致弹性、高性能、高可用性、高可靠性和安全性的数据库服务。 TDSQL-C 实现了超过百万每秒的高吞吐量,支持…

SpringCloud 学习(四)Hystrix

6. Netflix.Hystrix 6.1 简介 ● 扇出 多服务之间调用,若微服务 A 调用微服务 B 和微服务 C,微服务 B 和 微服务 C 又调用其他微服务,这就是扇出 ● 服务雪崩 若扇出的链路上某个微服务的调用响应时间过长或者不可用,么此扇出…

ESP32在CAN(TWAI)波特率不同时收发数据,导致总线错误无法恢复

问题描述: 总线上有两个设备,主机:100ms周期发送数据。从机:以不同波特率发送数据,再把从机波特率调节至主机波特率一致无法通信。 环境:VSCODE IDF-v5.0 问题分析: 我们先看下ESP32技术参…

Spring 学习(四)注解实现自动装配及注解开发

1. 注解实现自动装配 JDK 1.5 开始支持注解&#xff0c;Spring 2.5 开始支持注解。 使用须知 导入约束 配置注解的支持&#xff08; <context:annotation-config/> &#xff09; <?xml version"1.0" encoding"UTF-8"?> <beans xmlns&qu…

2023微信头像生成小程序,国庆头像生成,基于skyline+vue3+t

微信头像生成小程序&#xff0c;基于skylinevue3t该项目已适配微信小程序隐私政策&#xff0c;截图、获取头像等诸多新的接口 如何使用&#xff1a; 将代码导入到HBuilderX开发工具&#xff0c; 可无需修改任何代码&#xff0c;运行并编译到微信开发者工具 skyline需要使用微…

layui中使用JavaScript监听下拉框(select)的变化,根据选中的值来决定是否显示或隐藏input元素

HTML代码 <div class"layui-form-item" id"rubric"><label class"layui-form-label">前端说明</label><div class"layui-input-inline"><input type"text" id"user_rubric" name"…

页面添加遮罩层

1.css代码 // 子绝父相.self-check-tag {display: inline-block;min-width: 132px;height: 32px;position: relative;.overlay {position: absolute;top: 0;left: 0;width: 100%;height: 100%;background-color: gray;opacity: 0.1;}2.效果