嵌入式软件开发流程(个人心得)
wptr33 2025-01-21 21:57 23 浏览
一 背景
刚从学校出来实习那会儿,在深圳南山某龙电控公司上班,职位是售后维修,用伺服电机控制绣花机,有个显示终端应该用的是桌面系统。一进公司就开始修板子,在经过一番培训之后就出去驻场服务,看到软件开发工程师来支持我们的工作,他们没什么头发,大部分都戴着眼镜,看上去很厉害的样子,他们拿着示波器的探头,拿着万用表打到二极管档位,测量线路的通断,当时真的很想成为这样的人。
二 毕业后换工作
来到我人生中最重要的一家公司,有个老同事真的很热心,手把手教我怎么看原理图,为什么控制这个IO为高电平,三极管就输出低电平,为什么电磁阀可以动起来,怎么控制继电器,怎么写代码怎么画原理图,怎么画PCB板,一条龙服务毫无保留地非常耐心地指导我,部门经理在下班后,等我们吃完饭手把手教我们怎么用java与下位机通信,怎么创建线程,那段时光真的很美好,把我带进了软件开发行业。
三 感谢
非常感谢过去帮助过我的人,这个社会真的需要你们这样的人,特别是刚毕业的学生,进到这样一家公司真的是很不错的选择。
四 嵌入式软件开发流程
因为大部分做的是嵌入式开发,所以是按照这个话题来开展
4.1 好的软件深受4个人的喜爱和1个人的无奈
4.1.1 老板
通常老板都喜欢又快又好,交期快,订单量大。前期应该达不到,但有了良好的框架后理论上是可以达到这种效果的。
4.1.2 多个用户
傻瓜式操作、操作一步到位、快速上手、大量通俗易懂的手册、查阅文档自助解决问题、视频教程、技术支持快速响应(客服机器人)、稳定可靠不会崩溃满足一个用户是比较简单的,但是同时满足不同的用户就比较困难了,在技术支持方面我们需要引导用户自助解决问题、提供通俗易懂的用户手册。
4.1.3 同事
代码风格和编程思想良好、命名方式通俗易懂、有注释、良好的设计架构、阅读代码不会难受、有丰富的通俗易懂的技术文档,易于更新维护、易于跨平台移植、没有潜在的BUG。
4.1.4 自己
钱多事少,更新、维护、扩展、移植时只需更改少量代码、或不用改代码,软件测试、领导签字一次性通过,用户使用过程中体验良好,没有收到任何BUG反馈,深受用户喜爱。
4.1.5 软件测试
测了半天没有发现一个BUG,功能全部正常,一个版本都没有升,感觉太无聊,没有一点成就感,完全没有发挥他的价值,他会感到很迷茫,甚至开始怀疑人生但是没办法,只能委屈一下他了。
五 具体实施方法
5.1 现场考察
用户需求在开发之前,如果有现成的产品,最好去客户现场了解一下,就像做生意先要踩点记录一下人流量,人均消费水平,房租之类的同样的道理,我们需要知道:
5.1.1 用户使用现有产品体验是否良好,操作是否方便,如何改进
5.1.2 用户将来会遇到哪些问题
5.1.3 用户遇到问题时,如何通过我们提供的资源,他自己独立解决问题用户能够使用文档或者现有功能来自己解决问题,可结合公众号,服务器,数据库
5.1.4 总结哪些尚未被满足的、而又被广泛渴望的需求(用户痛点)
5.1.5 将以上用户需求转换成规范的开发计划、开发文档(硬件系统框架图、软件功能定义等)
5.2 设计原则
5.2.1 开闭原则
软件设计应该在满足功能需求的基础上增加一些东西当应用的需求改变时,在不修改软件实体的源代码或者二进制代码的前提下,可以扩展模块的功能,使其满足新的需求视觉反馈、触感反馈,为什么要有反馈,可能是一个很深奥的话题了,可能跟人体分泌的多巴胺有关系,我不确定。以不变应万变(无论用户需求有什么变化,我们都不用改固件),用户的可变动需求,还可以通过(GPIO)(拨码开关)或者其他通信接口来配置,把配置权交给硬件或者通信接口,交给用户
5.2.2 有软件框架和设计模式
5.2.3 有分层,做框架之前有个前提条件,要拿到功能定义、硬件系统框架图
分好层之后,分别编译成库文件,后续独立维护相应的库文件即可,便于移植减少维护时地相互影响,改动时不影响其他功能
5.2.4 稳定可靠
不出错,不崩溃(访问了空地址、内存溢出、内存泄露、数组越界、堆栈溢出等)
5.2.5 参数检查
有输入参数的函数,要有参数检查(排除所有可能的非法值)、错误处理、返回值用户输入是一个非常危险的事情,需要谨慎处理
5.2.6 自定义malloc
-不使用库函数malloc动态申请或释放内存创建内存池(静态),自己实现申请和释放的函数
-多任务时,需要对公共资源进行原子性访问,防止数据出错
5.2.7 重试机制
为了保证数据的有效传输,可能需要加入重试机制
5.2.8 易扩展、易维护更新软件时,更改代码量较少或无需更改代码
5.2.9 抽象变动部分
-改宏定义,或者类、静态链表、集合、数组等的定义,不更改过程将未来可能会变的部分抽象出来,定义成数组、静态链表、集合等,使用通用的过程来处理可变的部分
-不支持编程语法的将未来可能会变的部分抽象到外部文件(xml,bin),创建动态链表或者动态数组等再触发遍历
-支持编程语法的增加脚本解释器,将未来可能会变的部分抽象到外部脚本文件(asm,lua,js,html,php),创建动态链表或者动态数组等再触发遍历
5.2.10 有使用设计模式,例如工厂模式、创造者模式等
5.2.11 易维护,能够快速定位异常(追溯)
5.2.12 JAVA、VB.NET、C#,不确定C++有这种方法增加全局异常捕捉事件,抛出异常时将具体文件名和行号追加写入日志文件
5.2.13 有调试打印功能单片机可通过串口/LCD/并口(电脑主板)/PCI(电脑主板)来打印,串口/LCD/并口(电脑主板)/PCI(电脑主板)的读写字节函数映射到printf的相关读写字节函数上位机可通过控制台打印,输出到文件或者控制台窗口
5.2.14 软件层级之间通用的接口函数,便于移植跨平台
-write2.7.2 read
-control(cmd,data,void*parameter)可以不断地扩展新功能
-接口函数中void *作为输入参数,可以传递任意类型任意长度的参数
5.2.15 必要的错误码
帮助客户自主解决问题,依赖于函数有返回值
5.2.16 有自检功能
(硬件电路自检)、上电自检(通过指示灯来显示,用于检查IC,硬件电路等)3.1 当出现故障时,可通过系统自检来锁定问题,提示用户排除原因,解决问题能够便于移植(跨平台)的原因
5.2.17 分层设计
抽象出通用的类,通用的接口函数,除非资源太少,不能支持面向对象编程思想
例如GPIO类有什么属性,有什么接口函数,要兼容所有的平台,就要按照拥有最多的属性来做GPIO类
六 可实施步骤
嵌入式软件开发可以遵循一定的流程来执行:
6.1 总结用户需求,兼容多个用户的需求
6.2 了解现有方案,总结用户痛点(尚未被满足的、而又被广泛渴望的需求)
6.3 总结用户可能会遇到的困难
6.4 总结如何引导用户解决困难
6.4.1 将以上总结转换成规范的开发计划及技术文档
6.5 输出功能定义及设计要点(文档)
6.6 输出软件框架图(文档)
6.7 输出软件流程图(文档)
6.8 确认以上文档OK,开始写代码
6.8.1 确认好软件测试计划
6.9 软件测试(自己)
6.10 软件测试(正式),输出测试报告
6.11 更新改善
6.12 稳定性测试、可靠性测试、极端环境下测试
6.13 客户验收
6.14 客户现场跟踪,总结已知缺陷
6.15 持续改善
6.16 项目资料存档,输出测试文档
七 总结
以上是我以个人工作经验做的总结,不过我们的能力再好也要先提高自己的沟通能力,良好的沟通能力能够让我们打开彼此的心扉,让家庭更加和谐,让我们与朋友同事相处的更加融洽,让我们更好地开展工作,最大限度的发挥我们的工作经验和个人能力。
心有多大舞台就有多大,我现在也成了嵌入式软件工程师,但我还有更大的梦想,希望大家大胆去想象,大胆去挑战,一起努力去做到心想事成。
- 上一篇:这个标星 1.2k+ 的 GUI 引擎竟然支持跨平台开发
- 下一篇:大白话讲nnvm
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)