【软件工程】可行性研究

一、可行性研究

1. 可行性研究的任务与目的

  • 任务 :用最小的代价在尽可能短的时间内确定问题是否能够解决。
    需从以下方面分析:
    • 经济可行性
    • 技术可行性
    • 运行可行性
    • 法律可行性
    • 开发方案可行性
  • 目的:在明确目标系统的限制和约束后,判断问题是否值得解决。

2. 可行性研究过程

  1. 复查系统规模和目标
  2. 研究当前使用的系统
  3. 导出新系统的高层逻辑模型
  4. 进一步定义问题
  5. 导出和评价供选择的解法
  6. 推荐行动方针
  7. 草拟开发计划
  8. 书写文档提交审查

二、系统流程图

1. 定义与作用

  • 定义:描绘物理系统的传统工具,用图形符号以黑盒子形式表示系统部件(程序、文件、数据库、人工过程等)。
  • 作用
    • 在可行性研究中描述现有系统或建议系统的物理模型。
    • 表达部件的信息流程(非控制过程)。

三、数据流图(DFD)

1. 定义与特征

  • 定义:从信息传递和加工角度,图形化描述数据流的移动变换过程。
  • 特征
    • 抽象性:去除物理细节,仅保留数据流动和加工。
    • 概括性:整合多业务处理过程形成总体视图。

2. 组成元素

  • 外部实体(与系统交互的人或单位)
  • 数据流
  • 处理(加工)
  • 数据存储

3. 绘制步骤

  1. 识别输入/输出,画顶层图(上下文图)。
  2. 画内部数据流、加工与文件,生成一级细化图。
  3. 逐步分解加工,生成二级细化图。

4. 注意事项

  1. 数据守恒:每个处理必须有流入和流出数据流。
  2. 数据存储:必须有流入或流出数据流(缺一为Warning,缺二为错误)。
  3. 数据流规则
    • 只能在处理、数据存储、外部实体之间流动。
    • 禁止数据存储/外部实体之间的直接流动。
  4. 分层分解:处理可均匀分解为多层子图。
  5. 命名规范:元素需明确命名。

5. 其他要点

  • 父图与子图需保持平衡(输入/输出数据流一致)。
  • 信息流类型:交换流、事务流。

四、系统流程图 vs 数据流图

对比项 系统流程图 数据流图(DFD)
模型类型 物理模型 逻辑模型
描述重点 系统部件与信息流动 数据加工与流动
抽象层级 包含物理细节(硬件、人工等) 仅关注数据与处理逻辑

五、数据字典

1. 定义与内容

  • 定义:对DFD中元素的详细说明,补充DFD的语义描述。
  • 内容
    • 数据流
    • 数据元素(分量)
    • 数据存储
    • 处理逻辑
    • 外部实体

2. 作用

  • 为用户提供数据明确定义。
  • 帮助分析员修改系统逻辑模型。

六、成本效益分析

1. 目的

从经济角度评估新系统是否值得投资。

2. 效益度量方法

  1. 货币的时间价值
  2. 投资回收期
  3. 纯收入

小结

  • DFD需分层绘制,父图与子图保持平衡。
  • 系统流程图用于物理设计,DFD用于逻辑建模。
  • 数据字典是DFD的补充,确保数据定义清晰。
相关推荐
嘿黑嘿呦5 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
旧曲重听15 天前
2026前端技术从「夯」到「拉」
前端·程序人生·职场和发展·软件工程
承渊政道5 天前
飞算JavaAI 智能引导背后的多 Agent 协作机制解析:从老旧 Java 后台升级到可运行工程
java·开发语言·spring boot·安全·intellij-idea·软件工程·ai编程
apcipot_rain5 天前
计科八股20260616(1)——堆存中位数、链表判环、黑白测试、敏捷开发与瀑布模型、配置管理、持续集成、池化
数据结构·算法·软件工程
lisw056 天前
【计算机科学技术】路由器(route):概念、历史、内容与战略!
机器学习·智能路由器·软件工程
培培说证6 天前
大数据、人工智能、计算机、软件工程,到底怎么选?
大数据·人工智能·软件工程
文艺倾年7 天前
【强化学习】MDP、贝尔曼方程与CartPole 编程,20W字总结(二)
人工智能·软件工程·强化学习
郝学胜-神的一滴7 天前
CMake 017:彩色日志输出实战
linux·c语言·开发语言·c++·软件工程·软件构建·cmake
小程故事多_807 天前
AI软件工程范式革命,终结五十年的“手工伪工程”时代
人工智能·软件工程
精益数智小屋8 天前
项目管理看板如何拆解任务进度?项目管理看板解决跨部门协作难题
大数据·人工智能·数据分析·云计算·软件工程