当前位置: 首页 > news >正文

[架构之路-247]:目标系统 - 设计方法 - 软件工程 - 结构化方法的基本思想、本质、特点以及在软件开发、在生活中的应用

目录

前言:

一、什么是非结构化方法

1.1 什么是非结构化方法

1.2 非结构化方法的适用场合

二、什么是结构化方法

1.1 结构化方法诞生的背景:软件规模发展:大规模、复杂系统的需要

1.2 概述

1.3 主要特点与核心思想

三、结构化方法在软件开发中的应用

四、结构化方法在生活中的应用

五、结构化方法的本质

附录:软件架构开发流程


前言:

一、什么是非结构化方法

1.1 什么是非结构化方法

非结构化方法是一种与结构化方法相对的软件开发方法论。与结构化方法注重将系统分解为模块化、可管理的组件不同,非结构化方法更加灵活,没有明确的模块化和严格的控制流程

以下是非结构化方法的一些特点:

  1. 自由形式的设计和开发:非结构化方法中,系统的设计和开发没有严格的规定或特定的流程,开发者可以根据自己的理解和喜好来进行设计和开发。这种自由性的好处是可以灵活地调整和改变系统的功能和结构,适应不同的需求和变化。

  2. 缺乏明确的模块化和接口定义:与结构化方法不同,非结构化方法中的系统通常没有明确的模块化结构和明确定义的接口。相反,系统中的组件和功能往往是紧密耦合的,彼此之间缺乏明确的分离和独立性。

  3. 较低的可维护性和可重用性:由于缺乏明确的模块化和接口定义,非结构化方法开发的系统往往较难维护和修改。当需要对系统进行修改或添加新功能时,开发者可能需要涉及整个系统,而不仅仅是局部的某个模块。

  4. 度依赖开发者经验和技能:非结构化方法要求开发者具备较高的经验和技能,能够凭借个人能力和判断力来设计和开发系统。这也意味着非结构化方法的学习曲线较陡峭,并且项目的成败很大程度上取决于开发者个人的素质

尽管非结构化方法在某些情况下可能提供了一定的灵活性和自由度,但它也存在一些潜在的问题和挑战,包括难以维护、无法复用、缺乏可靠性和可扩展性等。因此,在实际软件开发中,结构化方法更常用,因为它提供了一种更系统化和可管理的方式来构建、测试和维护软件系统。

1.2 非结构化方法的适用场合

非结构化方法适用于以下场合:

  1. 创新性和实验性项目:对于一些具有探索性质和创新性的项目,非结构化方法可以提供更大的自由度和灵活性。这样的项目通常没有明确定义的需求和预期结果,需要通过不断尝试和调整来达到最终目标。

  2. 小规模项目:对于规模较小、简单的项目,非结构化方法可能更为合适。在这种情况下,过度的结构和约束可能会显得过于繁琐,而非结构化方法则能够更快速地进行开发,满足项目的需求。

  3. 快速原型开发:当需要快速开发原型以验证概念或进行用户测试时,非结构化方法可以提供更好的途径。这种方法注重快速迭代和试错,以尽快生成可演示的原型,并通过用户反馈进行迭代和改进

  4. 艺术和创意领域:在一些艺术、创意或设计领域,非结构化方法被广泛使用。这是因为创意过程有时更注重自由表达和想象力的发挥,而非结构化方法可以提供更大的自由度和创造力。

需要注意的是,尽管非结构化方法在某些情况下具有优势,但它也具有一些潜在的风险和挑战。缺乏明确的规范和流程可能导致项目失控,增加开发难度和风险,降低可维护性和可扩展性。因此,在选择使用非结构化方法时,需权衡其优缺点,并根据项目需求和团队条件做出合理的决策。

二、什么是结构化方法

1.1 结构化方法诞生的背景:软件规模发展:大规模、复杂系统的需要

结构化方法是20世纪60年代末到70年代初期随着信息技术和软件开发的飞速发展而崛起的一种软件开发方法论。在此期间,许多组织和企业开始开发越来越复杂、规模越来越大的软件系统庞大而复杂的软件项目往往难以处理和维护,而且很容易出现混乱和不可预测的问题

因此,许多软件开发者开始探索新的软件开发方法,并试图解决与复杂系统开发相关的问题。在此背景下,结构化方法应运而生。结构化方法正是为了应对这些问题而设计的——它们强调将复杂的系统分解为更小、更简单且易于管理的部分,从而使得项目更加可控和容易管控。

此外,70年代初期,尼克劳斯·沃斯(Niklaus Wirth)和埃德加·戴克斯特拉(Edsger Dijkstra)等软件开发领域的顶尖人才推广了模块化和结构化软件开发的概念。这促使结构化方法在计算机行业得到更广泛的应用和推广。

最初,结构化方法主要是用来支持大型企业级应用的设计和开发。但是,随着计算机技术和软件开发的迅速发展,结构化方法已经成为了一种普适的、通用的软件开发范式,为软件开发者提供了一种强大和有条理的方法。

1.2 概述

结构化方法是一种软件开发方法论,旨在帮助开发人员构建可维护、可理解和可扩展的软件系统。它强调将软件系统划分为模块化的组件,并定义它们之间的关系和交互,以及清晰而精确地描述数据流和控制流(数据面、控制面)

结构化方法的概述可以归纳如下:

  1. 模块化设计(分解):结构化方法强调将软件系统划分为相互独立、可重用的模块。每个模块具有明确的功能和职责,并定义了与其他模块之间的接口和交互方式。模块化设计使系统更容易理解、测试和维护。

  2. 高内聚低耦合:结构化方法鼓励每个模块具有高内聚性,即模块内的组件紧密相关并协同工作,同时与外部模块保持较低的耦合,以减少系统之间的依赖。这样可以提高软件的可重用性、灵活性和可扩展性,减少系统修改时产生的影响。

  3. 明确定义的接口:在结构化方法中,每个模块都有一个明确定义的接口,该模块的所有外部交互都通过该接口进行。这些接口定义了每个模块如何与整个系统互操作,还有如何通过模块接口进行数据传输和调用其他模块。这种接口定义使得整个系统更加透明和可控。

  4. 逐步求精、逐步分解(串行):结构化方法鼓励迭代和渐进式开发。开发人员通过不断地分析、设计、编码和测试,逐步完善软件系统。这种逐步求精的方式可以提高开发效率、减少风险,并确保软件系统满足最终用户的需求。

  5. 结构化控制流程:结构化方法注重使用结构化的控制流程,如顺序结构、选择结构和循环结构,以提高代码的可读性和清晰度。结构化控制流程的优点是能够更好地控制程序逻辑,并减少潜在的错误。

总体而言,结构化方法的核心思想是将复杂的软件系统划分为更小、更简单的部分,并利用清晰的数据流和控制流来设计和实现这些部分。这种方法能够提高软件系统的可理解性、可维护性和可扩展性,使开发过程更加可控和可预测

1.3 主要特点与核心思想

结构化方法是一种软件开发方法论,具有以下方法论特点:

  1. 独立模块化设计:结构化方法的主要思想是将“大系统”分解为相互独立的小模块,并对每个模块进行设计和开发,以便它们能够独立测试和修改。设计人员和程序员应该专注于单个模块,并确保该模块内部的所有组件相互协作,从而为更大的软件系统奠定了基础。

  2. 明确定义的接口:在结构化方法中,每个模块都有一个明确定义的接口,该模块的所有外部交互都通过该接口进行。这些接口定义了每个模块如何与整个系统互操作,还有如何通过模块接口进行数据传输和调用其他模块。这种接口定义使得整个系统更加透明和可控。

  3. 结构化控制流程:这种方法还强调采用结构化的流程控制,即顺序结构、选择结构和循环结构等,以提高代码的可读性和可理解性。良好的代码结构可以使开发人员更轻松地管理代码,从而更准确和快速地定位错误。

  4. 分阶段串行开发:结构化方法要求分阶段的开发,即将整个开发过程分为不同的部分,从整体规划开始,到具体实现。这些不同的开发阶段具有不同的目标和要求,从而能够更好地控制开发进度和保证质量。

  5. 逐步求精:该方法鼓励开发人员逐步求精,即通过不断迭代和完善,不断提高软件质量和可维护性。每个迭代周期都会对上一版本的软件进行测试和分析,从而使得软件不断接近最终用户的需求。

结构化方法的方法论强调模块化、低耦合、高内聚、结构化控制流程和分阶段逐步完善等原则,这些原则能够提高软件开发效率和质量。而且结构化方法并不能解决所有的软件系统问题,有些情况下也会受到历史因素、组织限制和技术因素等因素的影响。因此,开发人员需要根据实际情况合理地选用和应用结构化方法,才能更好地构建高质量的软件系统。

三、结构化方法在软件开发中的应用

结构化方法是一种软件开发方法论,其目的是通过建立结构化的设计和分析过程来有效地开发和维护高质量的软件系统。

以下是结构化方法在软件开发中的几个常见应用:

  1. 结构化分析-需求阶段=》分解功能:结构化分析是一个系统化的过程,通过对问题领域的需求进行分解和定义,确定系统的功能和数据流程。在结构化分析中,可以使用工具如实体关系图(功能划分)数据流图数据字典来表示系统的逻辑组件数据流动,以便更好地理解和描述系统的需求和功能。

  2. 结构化设计-设计阶段=》分解模块:结构化设计着重于将系统的功能(需求阶段)划分为模块化的组件(设计阶段),以便于系统的开发和维护。在结构化设计中,可以使用工具如结构图和层次图来表示系统的模块结构和模块之间的关系。通过结构化设计,可以提高系统的可扩展性和可维护性。

  3. 结构化编程-编程阶段=》分解语句结构化编程是一种编码风格,通过使用结构化语句(如顺序、选择和循环)来编写清晰、可读性高的代码。结构化编程强调良好的程序结构和模块化,使得程序更易于理解、测试和维护

  4. 结构化测试-测试阶段=》分解用例结构化测试是一种以系统的结构为基础的测试方法,通过执行特定的测试用例来验证系统的功能和正确性。在结构化测试中,通过控制流和数据流覆盖来确保测试用例覆盖系统中的所有代码路径,检测潜在的错误和缺陷。

  5. 结构化文档-所有阶段=》分解文档结构化方法强调对软件系统进行良好的文档记录。通过结构化文档,可以清晰地描述系统的需求、设计、实现和测试过程,以便于后续的维护和开发工作。

结构化方法在软件开发中的应用有助于提高开发效率、降低错误率,并提供清晰的架构和文档支持。然而,随着软件开发方法的不断演进和新技术的出现,结构化方法已经和其他方法相结合使用,以满足不同项目和需求的要求。

四、结构化方法在生活中的应用

结构化方法不仅可以应用于软件开发,还可以在日常生活中帮助我们更有效地组织和管理各个方面。以下是结构化方法在生活中的几个应用:

  1. 时间管理:结构化方法可以帮助我们更好地管理时间,确保高效利用每一天。通过设定目标、制定计划和优先级,可以将时间分配给不同任务和活动,并确保按计划完成

  2. 任务和项目管理:在生活中,我们经常面临多个任务和项目,如家庭事务、个人目标、工作项目等。结构化方法可以帮助我们将任务和项目分解为可管理的子任务,并为每个子任务设定具体的时间和资源限制,以便更好地组织和执行。

  3. 目标设置和追踪:结构化方法可以帮助我们明确并设定具体、可衡量的目标。通过将目标细分为可行动的步骤和阶段,并制定明确的时间表和行动计划,可以更有序地追踪和实现目标。

  4. 决策制定:结构化方法可以在决策制定过程中提供指导和框架。通过对问题进行分析和评估,收集相关信息并权衡不同的选项,可以帮助我们做出理性、明智的决策。

  5. 笔记和记录管理:结构化方法可以应用于笔记和记录的管理,使得信息更易于查找和回顾。例如,可以使用分类和标签来组织笔记,使用时间表或日志来追踪进展和事件。

总体而言,结构化方法可以帮助我们更好地组织、规划和管理生活中的各个方面,提高效率、减少混乱,并增加我们的生活质量。但需要根据自己的需求和偏好来对方法进行个性化调整,以适应个人的生活方式和目标。

五、结构化方法的本质

结构化方法的本质在于提供一种系统化、有组织的方式来处理复杂问题和任务,以产生高质量的结果。因此,结构化方法,并非仅仅用于软件需求分析、软件架构设计、软件编程等领域,其思想可用于解决任何复杂问题

结构化方法强调以下几个重要的方面:

  1. 分解和组织:结构化方法鼓励将大问题或任务分解为更小、更可管理的部分。通过将复杂的系统或任务分解为模块化的组件,并定义它们之间的关系和交互,可以更容易地理解和处理问题。

  2. 层次和逻辑:结构化方法注重层次和逻辑的建立。通过建立清晰的结构和层次关系,可以使问题或任务的处理过程更清晰、有条理。层次结构可以使得问题的不同层次可分解为更小的子问题,并有效地处理各个层次之间的关系。

  3. 逐步求精、逐步分解(串行):结构化方法鼓励迭代和渐进式开发。开发人员通过不断地分析、设计、编码和测试,逐步完善软件系统。这种逐步求精的方式可以提高开发效率、减少风险,并确保软件系统满足最终用户的需求。

  4. 规范和标准结构化方法倡导使用规范和标准化的方法来进行问题和任务的处理。这有助于确保一致性、可重复性,并提高结果的质量。通过遵循规范,可以减少不确定性和错误的可能性,结构化方法把软件的生产分为了几个标准化的阶段:需求分析、架构设计、详细设计、软件编程、测试验证等。

  5. 可视化和表达结构化方法鼓励使用可视化工具和技术来表达问题和任务的结构和关系。例如,使用图表、流程图、结构图等来表示系统结构和流程。这有助于促进理解、交流和共享知识。

  6. 可管理性和可维护性结构化方法的目标之一是提高问题和任务的可管理性和可维护性。通过将复杂的问题分解为可管理的部分,建立清晰的关系和规范,可以更轻松地进行追踪、测试和维护。

结构化方法的本质是将复杂性以结构化和系统化的方式处理,以便更好地理解、组织和解决问题。它提供了一组原则和技术,以促进高效、可靠和可维护的结果的产生。

附录:软件架构开发流程

相关文章:

[架构之路-247]:目标系统 - 设计方法 - 软件工程 - 结构化方法的基本思想、本质、特点以及在软件开发、在生活中的应用

目录 前言: 一、什么是非结构化方法 1.1 什么是非结构化方法 1.2 非结构化方法的适用场合 二、什么是结构化方法 1.1 结构化方法诞生的背景:软件规模发展:大规模、复杂系统的需要 1.2 概述 1.3 主要特点与核心思想 三、结构化方法在…...

大模型的交互能力

摘要: 基础大模型显示出明显的潜力,可以改变AI系统的开发人员和用户体验:基础模型降低了原型设计和构建AI应用程序的难度阈值,因为它们在适应方面的样本效率,并提高了新用户交互的上限,因为它们的多模式和生…...

80%测试员被骗,关于jmeter 的一个弥天大谎!

jmeter是目前大家都喜欢用的一款性能测试工具,因为它小巧、简单易上手,所以很多人都愿意用它来做接口测试或者性能测试,因此,在目前企业中,使用各个jmeter的版本都有,其中以jmeter3.x、4.x的应该居多。 但是…...

Git——感谢尚硅谷官方文档

Git——尚硅谷学习笔记 第1章 Git 概述1.1 何为版本控制1.2 为什么需要版本控制1.3 版本控制工具1.4 Git 简史1.5 Git 工作机制1.6 Git 和代码托管中心 第2章 Git 安装第 3 章 Git 常用命令3.1 设置用户签名3.2 初始化本地库3.3 查看本地库状态3.4 添加暂存区3.4.1 将工作区的文…...

Java WebSocket框架

引言 随着互联网和移动互联网的迅猛发展,实时通信成为了应用程序的一项重要能力。WebSocket作为一种在Web上实现双向通信的协议,极大地丰富了Web应用程序的交互方式。而在Java领域,也有许多优秀的WebSocket框架可供选择,本文将介…...

C#实现本地服务器客户端私聊通信

(一)需求 在游戏中我们经常能够看到玩家与玩家之间可以进行私聊,在QQ或微信中最基本的功能就是用户与用户之间的通信。抽象成计算机网络,就是两个客户端通过服务器进行私聊通信,两个客户端可以互相看到对方发送过来的信…...

PyTorch 之 Dataset 类入门学习

PyTorch 之 Dataset 类入门学习 Dataset 类简介 PyTorch 中的 Dataset 类是一个抽象类,用来表示数据集。通过继承 Dataset 类可以进行自定义数据集的格式、大小和其它属性,供后续使用; 可以看到官方封装好的数据集也是直接或间接的继承自 …...

Java update scheduler

引言 Java 更新调度器是 Java 中的一个特性,可以自动化 Java 应用程序的更新过程。它提供了一种方便的方式来安排 Java 应用程序的更新,确保其与最新的功能、错误修复和安全补丁保持同步。本文将深入介绍如何使用 Java 更新调度器,并解释它对…...

常见树种(贵州省):006栎类

摘要:本专栏树种介绍图片来源于PPBC中国植物图像库(下附网址),本文整理仅做交流学习使用,同时便于查找,如有侵权请联系删除。 图片网址:PPBC中国植物图像库——最大的植物分类图片库 一、麻栎 …...

拓扑排序-

有向无环图是拓扑排序 拓扑排序将图中所有的顶点排成一个线性序列,使得所有的有向边均从序列的前面指向后面。 拓扑排序使用深度优先搜索来实现,图中有环则无法进行拓扑排序 一个有向图,如果图中有入度为0的点,就把这个点删掉…...

Oracle数据库如何定位trace file位置

用一个示例来说明吧。 在导入master key时,出现错误: ADMINISTER KEY MANAGEMENTIMPORT KEYS WITH SECRET "my_secret"FROM /tmp/export.expIDENTIFIED BY keypwd5 WITH BACKUP; ADMINISTER KEY MANAGEMENT * ERROR at line 1: ORA-46655…...

电脑盘符错乱,C盘变成D盘怎么办?

在一些特殊情况下,磁盘盘符会出现错乱,C盘可能会变成D盘。那么,这该怎么办呢?下面我们就来了解一下。 通过磁盘管理更改盘符 磁盘管理是Windows自带的工具,它位于“计算机管理”的控制台中。管理硬盘及其所包含的卷或…...

Android WMS——客户端输入事件处理(十九)

前面的文章我们介绍了 WMS 中的输入服务的启动及事件处理,这一篇我们来看一下客户端对输入事件的处理。 一、事件初始化 事件的初始化就是在添加窗口的过程。 1、ViewRootImpl 源码位置:/frameworks/base/core/java/android/view/ViewRootImpl.java public void setView(…...

Python基础学习__测试报告

# 使用pycharm生成报告:只有在单独执行一个TestCase文件时可以生成,使用TestSuite等就不能用了 # 使用第三方的测试报告:例如:HTMLTestRunner第三方类库 #使用HTMLTestRunner这个执行对象# 1.获取第三方的测试运行类Runner模块(一个py文件),将其放在代码目录下 # 2.导包:unitte…...

bclinux aarch64 ceph 14.2.10 云主机 4节点 fio

ceph -s 由于是基于底层分布式存储的云主机,数据仅供参考 本地云盘性能 direct1 1M读取 IOPS134, BW134MiB/s [rootceph-client rbd]# cd / [rootceph-client /]# fio -filenamefio.bin -direct1 -iodepth 128 -thread -rwread -ioenginelibaio -bs1M -size10G -n…...

智能座舱架构与芯片- (14) 测试篇 上

一、 验证平台概要 1.1 测试软件方法论 “软件定义汽车” 的时代,软件在整车制造中的重要性日渐凸显。但不同于其他行业的软件开发,汽车行业有自己独特的软件开发要求。首先是需求严谨、需求层次复杂、需要通过专业的工具进行管理;其次开发…...

【Django-DRF用法】多年积累md笔记,第3篇:Django-DRF的序列化和反序列化详解

本文从分析现在流行的前后端分离Web应用模式说起,然后介绍如何设计REST API,通过使用Django来实现一个REST API为例,明确后端开发REST API要做的最核心工作,然后介绍Django REST framework能帮助我们简化开发REST API的工作。 全…...

Redis主从复制,哨兵和Cluster集群

主从复制: 主从复制是高可用Redis的基础,哨兵和集群都是在主从复制基础上实现高可用的。主从复制主要实现了数据的多机备份(和同步),以及对于读操作的负载均衡和简单的故障恢复。 缺陷:故障恢复无法自动化…...

Linux嵌入式I2C协议笔记

硬件: 1.I2C结构 在一个SOC中有一个或者多个I2C控制器,一个I2C控制器可以连接一个或多个I2C设备。 I2C总线需要两条线,时钟线SCL和数据线SDA 2.I2C传输数据格式 开始信号(S):SCL为高电平时,S…...

科技的成就(五十三)

503、任天堂首次公开 Switch 2016 年 10 月 20 日,任天堂首次公开 Switch 正式名称及造型。Switch 是任天堂推出的混合型游戏机,可作为家用游戏机,也可作为便携式掌机。Switch 在开发过程中就以代号 NX 而闻名,成为当年的现象级产…...

Vim 调用外部命令学习笔记

Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...

基于大模型的 UI 自动化系统

基于大模型的 UI 自动化系统 下面是一个完整的 Python 系统,利用大模型实现智能 UI 自动化,结合计算机视觉和自然语言处理技术,实现"看屏操作"的能力。 系统架构设计 #mermaid-svg-2gn2GRvh5WCP2ktF {font-family:"trebuchet ms",verdana,arial,sans-…...

Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?

Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...

中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试

作者:Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位:中南大学地球科学与信息物理学院论文标题:BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接:https://arxiv.…...

Java如何权衡是使用无序的数组还是有序的数组

在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

深入理解JavaScript设计模式之单例模式

目录 什么是单例模式为什么需要单例模式常见应用场景包括 单例模式实现透明单例模式实现不透明单例模式用代理实现单例模式javaScript中的单例模式使用命名空间使用闭包封装私有变量 惰性单例通用的惰性单例 结语 什么是单例模式 单例模式(Singleton Pattern&#…...

MVC 数据库

MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...

质量体系的重要

质量体系是为确保产品、服务或过程质量满足规定要求,由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面: 🏛️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限,形成层级清晰的管理网络&#xf…...

css的定位(position)详解:相对定位 绝对定位 固定定位

在 CSS 中,元素的定位通过 position 属性控制,共有 5 种定位模式:static(静态定位)、relative(相对定位)、absolute(绝对定位)、fixed(固定定位)和…...

服务器--宝塔命令

一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...