[软件工程]—嵌入式软件开发流程

嵌入式软件开发流程

1.工程文件夹目录

├─00_Project_Management
├─00_Reference
├─01_Function_Map
├─02_Hardware
├─03_Firmware
├─04_Software
├─05_Mechanical
├─06_FCT
└─07_Tools
  • 00_Project_Management

子文件夹如下所示:

├─00_需求导入_QFD
├─01_需求约束_Pugh
├─02_需求转化_Basic_Static
├─03_功能图谱_Function_Map
├─04_功能风险管控_DFMEA
├─04_法规认证_国内_国外
├─04_知识产权_国内_国外
├─05_敏捷开发_Scrum
├─06_持续集成与测试_DevOps
├─07_产品生产与管理_Six_Sigma
└─08_缺陷管理追踪_Jira
  • 00_Reference

参考文件,如datasheet。

  • 01_Function_Map

功能图谱,包括哪些功能以及如何实现。

  • 02_Hardware

硬件,比如PCB文件。

  • 03_Firmware

固件,如单片机库文件、bootloader、中间件、RTOS。

  • 04_Software

软件工程代码;调试用的自己开发的上位机等。

  • 05_Mechanical

产品结构相关文件。

  • 06_FCT

生产相关,测试上位机等。

  • 07_Tools

使用的开发工具、测试脚本、固件加密等。

2.开发流程

2.1 需求分析导入(QFD)

QFD是一种生成计划矩阵的工具:

  • 获取客户需求并将其明确。
  • 确保服务与客户要求一致。
  • 理解客户需求与服务需求的关系。
  • 按需求的优先顺序指导服务需求。
  • 确定我们在技术、测量和竞争性方面的差距。
  • 将服务需求进一步分解。
  • 追踪在弥补差距方面所取得的进步。

2.2 需求约束(Pugh)

Pugh矩阵式一种需求分析与约束的工具;

  • 进一步探求客户本质需求。
  • 将需求之间的交叉点提取出来。
  • 对需求的初步实现方案进行初步简单甄别。
  • 研究清除每个功能对于各个功能之间的影响。

2.3 功能图谱(Function Map)

功能图谱是一种可视化工具,它帮助我们在开发过程中系统的组织和管理系统中应用的所有功能:

  • 获取并明确功能需求。
  • 确保系统功能与用户要求相一致。
  • 理解功能需求与系统需求的关系。
  • 按需求优先顺序指导功能开发。
  • 确定在技术、测量和竞争性方面的差距。
  • 将功能需求进行进一步分解。

2.4 法规认证

拥有法规认证就能得到一部分机构的背书,产品才能进入某个国家、地区以及对应的行业。

2.5 知识产权审查与规划

通过知识产权的布局,能够让我们的产品形成知识产权的壁垒,包括不限于专利、品牌、技术交叉授权等。

2.6 功能风险管控(DEMEA)

通过DFMEA,企业可以在设计阶段提前识别和处理潜在风险,减少产品上市后的故障和召回,提高产品可靠性和客户满意度,同时降低成本和提高市场竞争力。

2.7 敏捷开发(Scrum)

Scrum框架有助于团队更加灵活开展软件开发工作,提高项目交付的质量、效率和客户满意度。

2.8 持续集成与测试(DevOps)

加速了软件交付,提高了软件质量,降低了风险,并促进团队的协作和持续改进。

2.9 产品生产管理(Six Sigma)

Six Sigma在产品生产管理中的主要作用是通过改进生产过程、降低成本、提高质量和客户满意度,推动企业实现持续的质量和业务增长。

  1. 过程改进
  2. 减少变异性
  3. 降低成本
  4. 提高客户满意度
  5. 数据驱动决策
  6. 培养团队素质
  7. 持续改进

2.10 缺陷管理追踪(Jira)

Jira作为一种强大的项目管理和协作平台,在缺陷管理追踪方面提供了丰富的功能和灵活的定制选项,从而提高产品质量和团队生产效率。

3. 敏捷开发

3.1 敏捷开发与瀑布式开发区别

瀑布式开发流程如下,整个流程一次进行、有可能导致最终产品不符合客户需求或落后于市场需求,导致推翻重做,进而影响效率。

敏是开发先做出一个最小系统,然后在已有的功能上不断迭代进行完善,迭代过若干轮后完成最终产品。

3.2 角色、文档、会议

  • 角色:

    • 产品经理:负责确定产品特性、产品亮点。
    • 团队负责人:负责团队工作,进行不同人员的沟通与协作。
    • 团队成员:开发、测试等。
  • 文档

    • 产品需求列表:将用户需求进行整理,在每个迭代周期中进行规划。
    • 用户故事:明确用户需求,排优先级。
    • 燃尽图:表示项目进度。
  • 会议

    • 迭代周期计划会议(SprintPlanning):用于评估用户需求与工作量。
    • 每日例会:沟通团队人员进度。
    • 迭代周期回顾会议(SprintReview):展示最终成功,并沟通继续改进。

3.3 工作流程

相关推荐
代码欢乐豆2 天前
第12章小测
软件工程
田梓燊2 天前
湘潭大学软件工程算法设计与分析考试复习笔记(四)
笔记·算法·软件工程
shinelord明2 天前
【再谈设计模式】适配器模式 ~接口兼容的桥梁
数据结构·设计模式·软件工程
张彦峰ZYF2 天前
互联网数字化商品管理浪潮思考:从信息化到精准运营
大数据·软件工程·软件需求
代码欢乐豆2 天前
软件工程9、10章小测
软件工程
夏子曦2 天前
说说软件工程中的“协程”
软件工程
张彦峰ZYF3 天前
DDD领域应用理论实践分析回顾
分布式·架构·系统架构·软件工程
喵~来学编程啦3 天前
【软件工程】一篇入门UML建模图(类图)
软件工程·uml
Cristiano永远是goat3 天前
软件工程期末复习-用例建模
软件工程
科技新知3 天前
小米顾此失彼:汽车毛利大增,手机却跌至低谷
智能手机·汽车·软件工程