历史上的今天
返回首页

历史上的今天

今天是:2025年12月26日(星期五)

正在发生

2022年12月26日 | 怎么看懂别人写的单片机项目代码

2022-12-26 来源:zhihu

记得刚开始接触代码的时候,总觉得很神秘,也好奇到底是怎样的牛人,才能把这么多复杂的”天书”写出来去。


当时多希望自己一夜之间也拥有这种能力,能自己写代码去把自己的想法通过技术的手段制造出来。


现实哪有这么好的事,任何一项能力,必须都要经过破茧成蝶的痛苦过程。


记得我第一份单片机开发的工作,掉头发的数量也是历史之最,也是导致我现在发际线变高的罪魁祸首。


那个时候是第一次真正意义上去做实际产品开发,公司也没敢让我参与新产品研发,而是维护老产品,就是改改代码升级下产品功能。


我记得很清楚,当时要维护一个MF刷卡权限管理的控制板,用的是STC的单片机。


那个时候死磕MF卡的东西,比如说MF卡内部的扇区分布以及初始化流程,相当的复杂。


程序很多也没注释,有些注释甚至是错的,我足足研究了1个月,才摸到一点头绪。


其实当初是走了弯路,根本没必要去研究MF卡的初始化流程和寄存器配置。


因为那些一般都会有厂家提供,就像我们LCD驱动一样。


如果你去研究这个,所花的时间至少增加1倍,很不划算。


如果大家从事单片机开发,那看别人写的代码可以说是你的必经之路。


千万不要指望你的水平能通过同事帮助你提高,最后只能靠你自己付费另外去学习,或者你看那些大神写的代码慢慢去沉淀。


今天就跟大家分享下如何高效看懂别人的程序代码,这项能力决定你成长的速度,非常重要!


我也是培养了自己这项能力,才把一些很多协议栈挖的比较深。


比如说我把蓝牙协议栈的系统提取出来,去掉蓝牙部分代码,经过改良移植到STM32上面为己所用,实际比他们协议栈占用的资源更少。


当然,功能也没他们的强大,我们只需要够用就行。

如果用TI蓝牙芯片开发过产品的小伙伴应该对这个代码也比较熟悉了。

看别人代码是非常头痛的事情,现在我们无际单片机编程学到第二个项目的学员应该深有体会。

第二个项目的代码吃透就是3-5年工程师水平可不是说着玩的,毕竟是我多年经验总结,一下就想吃透不现实。

大家一定要记住,必须遵循正确的学习顺序去学习,否则很难吃透。

下面分享下个人的经验。

我总结以下几点:

  1. 先看懂程序整体架构

  2. 从main函数开始逐渐深入

  3. 细节功能分析方法

一、先看懂程序整体架构

我们在拿到一个程序之前,先不急着看代码,先把整体架构捋清楚。

我拿我们主机那个项目来举例。

整个项目的程序可以拆分为三大板块:

实际上大多数单片机开发的项目都必备STM32外设驱动代码和产品功能代码。
系统内核代码,可能很多没有,这个类似于RTOS。

1.STM32外设驱动代码

也就是我们这个项目的主控芯片,这个板块主要是完成我们项目用到的STM32外设驱动代码。

这也是整个项目的基础,你必须要先熟悉STM32的外设怎么用起来,才能去研究产品功能代码,也就是第2,3板块。

可以利用现有的资源,比如说某子,某火的视频教程去学习STM32的外设使用。

2.系统内核代码

我们这个项目和传统产品代码不一样,传统的可能所有函数在while(1)死循环里面调用各种函数完成产品功能。

我们加入了一个自己写的小系统在里面,所有功能函数通过模拟任务管理的形式去执行,虽然最终也是在while(1)死循环里。

这样做的好处是可以灵活控制每个函数的执行频率和次数。

系统内核代码一般是一种程序框架,通用性比较强,所以相对比较复杂一点。

像这种代码,我不太建议新手上来就把它吃透,而是先学会移植。

就像RTOS一样,你不可能自己从头到尾写一个RTOS。

正确的学习顺序是,你先要移植,移植完以后知道怎么用。

用熟了以后,你慢慢也知道各个函数和变量的作用了,这个时候再去深挖实现的细节,最终吃透自己从零开始写出来。

这个非常重要,我发现很多新手没有这种意识。

总是纠结自己为什么写不出来,这是我几年经过数十产品锤炼出来的,看下教程就能写出来,这门槛未必也太低了对吧?

如果不纠正这个错误,很有可能你就卡在这个坎上了。

3.产品功能代码

刨去STM32外设驱动,刨去项目可能存在的系统,剩余的就是产品功能代码了。

二、从main函数开始逐渐深入

一个产品的功能再复杂,它都必须从main开始。

所以,我们分析程序的时候,一定要抓住程序的”喉咙”:main函数。

同样,在看代码之前,一定要对产品的功能有个系统的了解,否则就是看天书。

一般来说,只要你看的那个项目代码不会太差,main函数里通常都是通过调用各种函数去实现产品的功能。

而不会说直接在main函数里写所有功能的代码。

比如说我们这个程序,就是不同的功能模块,有不同的处理函数。

首先,我们先要熟悉每个功能模块需要实现的功能是什么,有了这个概念再去看代码。

最后通过AppProc这个函数完成各个功能模块的逻辑整合。

这些功能第一遍不需要吃透,你只需要知道大概先了解一下,用熟了再深入到细节实现。

三、细节功能分析方法

最后就是细节功能的分析了,细节功能是什么?

也就是我们产品的功能,比如说LED特效指示、按键检测、OLED菜单显示、蜂鸣器提示音等等。

这种要怎么去分析?

你先要熟悉功能,然后根据功能先想想如果是你,你要这么去实现这个功能?

自己先想一遍,甚至动手写一遍,不管有没有做出来,这时再去理解别人的代码。

思考一下,别人为什么要这么写,和你的写法有什么各自的优缺点,这一波操作虽然费时间,但是绝对值得你投入。

如果你连别人实现什么功能都不知道,就盲目去看代码,无疑是自讨苦吃走弯路。

我给大家举个简单的例子吧,比如让LED每秒闪1次这个功能的代码。

不同的工程师,经验和水平不一样,实现的方法肯定也不一样。

你想这个功能可能很简单,我就用一个定时器,定时频率是500ms,然后再定时中断里让LED控制引脚的电平翻转,这样就能实现LED每秒闪1次了。

但是你考虑过这样做的缺点没有?我总结一下:

①浪费资源

搞一个定时器专门用来做LED闪烁,这也太浪费了,一个单片机总共才多少个定时器?

②可扩展性差

如果下一次产品改板,加了10个灯,每个灯有不同的指示效果。

比如说:

LED1,要求产品未连上网以前每200ms闪1次,联网过程每400ms闪1次,连上网以后常亮。

LED2要求每按一个按键,就亮500ms,然后灭。

其他还有乱七八糟的特效,这种你试试用前面那种方式去实现,实现起来明显很麻烦!

所以,这就是为什么,明明你觉得很简单的功能,别人要绕一个大圈去实现。

就像我写的LED特效的程序,原理就是通过数组存储不同时间段引脚的状态,然后配合定时器把这个波形(PWM)在引脚里展现出来,实现不同LED特效的功能。

其实,如果你以前没做过LED特效的话,一下去理解别人踩过很多坑的代码是很困难的。

你要做的就是先要学会用,比如说你可以在我程序基础上改个特效试试。

等你真正学会了用,你会发现,你根本不用重头自己写,我这个代码都是通用性很强的。

你只需要把我代码移植到自己的产品上,根据自己产品需求,修改一些参数,就可以快速实现LED特效功能。

比如说,原来我的产品只有一个LED1,现在要新增加一个LED2,那你只需要在头文件LED枚举定义增加一个LED2:

当然,STM32的引脚配置,你也要增加一个GPIO来控制LED2。

就是要发散你的思维,先在我的代码框架基础去修改功能,然后烧录测试。

要不断循环这个过程,最终你才能吃透代码,而不是你光看视频去吃透,这个想法是错误的。

最后总结:

  1. 拿到一个项目代码,先熟悉产品功能。

  2. 熟悉产品的程序框架,都由哪些功能模块组成。

  3. 多尝试改每个功能模块的代码,测试一下效果。

  4. 改熟了再去分析他们具体实现的代码。

  5. 尝试自己写。

反正,就是要先熟悉,再修改测试效果,最后再自己写。


推荐阅读

史海拾趣

CLARE公司的发展小趣事

CLARE公司始终坚持品质至上的原则,从原材料采购到生产制造、质量检测等各个环节都严格把控,确保产品的品质和性能达到客户的期望。同时,公司还建立了完善的售后服务体系,为客户提供及时、专业的技术支持和服务。这些举措赢得了客户的信赖和好评,为CLARE公司的长期发展奠定了坚实的基础。

Cantherm公司的发展小趣事

随着电子市场的日益竞争,Cantherm公司面临着市场拓展的难题。为了打开新的销售渠道,公司决定加大在国际市场的宣传力度,同时积极参加各种电子行业的展会和论坛。通过与国际同行的交流与合作,Cantherm不仅提升了品牌知名度,还成功拓展了海外市场,实现了业务的多元化发展。

Coil-Q Corporation公司的发展小趣事

随着全球环保意识的提高,Coil-Q积极响应绿色发展的号召,将环保理念融入公司的生产和经营中。公司投入大量资金研发环保材料和技术,优化生产工艺,降低能耗和排放。同时,Coil-Q还积极参与环保公益活动,推动行业的绿色转型。

Exel Microelectronics Inc公司的发展小趣事

在XXXX年,Exel Microsystems Inc迎来了一次重要的技术突破。公司成功研发出了一款高性能、低功耗的微控制器芯片,这款芯片在行业内引起了广泛关注。该芯片不仅满足了当时市场对高性能微控制器的需求,而且其低功耗的特性也大大降低了设备的运行成本。这一技术突破为Exel赢得了大量订单,公司的市场份额也得到了显著提升。

全鹏(CHAMPION)公司的发展小趣事

为了提升国际市场竞争力,全鹏公司一直致力于提高产品质量和管理水平。在2014年,全鹏电子科技有限公司成立,并成功通过了ISO9001国际质量管理体系、ISO14001环境管理体系认证和汽车与医疗器材体系IATF/16949认证。这些认证不仅证明了全鹏公司在质量管理方面的实力,也为其在国际市场上赢得了更多的信任和机会。

Holmes Co Inc公司的发展小趣事

为了进一步提升竞争力,Holmes Electronics采取了一系列并购重组措施。他们首先收购了一家在物联网技术方面具有深厚积累的小型科技公司,通过整合双方资源,迅速在智能家居和智慧城市领域取得突破。随后,公司又成功并购了一家专业的半导体封装测试企业,进一步完善了产业链布局。这些并购重组不仅增强了Holmes Electronics的技术实力和市场地位,还为公司带来了新的增长动力。

问答坊 | AI 解惑

TPMS汽车的永恒主题

 对IC整合度和可靠性提出新要求   由于汽车轮胎现在大多都是没有内胎的真空子午胎,因此,将T PMS的远程轮胎压力监测模块安装在轮毂上是十分方便和容易的。但 是汽车在高速跑动时轮胎内环境和温度是十分恶劣的,压力、温度、 湿度变化特别大 ...…

查看全部问答>

全国电子设计竞赛从今天开始了!

本帖最后由 paulhyde 于 2014-9-15 09:29 编辑 希望今天参加全国电子设计竞赛的同学加油!加油!我们必胜!  …

查看全部问答>

如何得知系统播放声音的状态

我们目前在做一个语音方面的软件,希望在其它的程序例如(MEDIAPLAYER)正在播放的时候做相应的处理,请问大家我们有可能得到系统播放的声音时候获得状态吗?200分相赠:)…

查看全部问答>

求教手机液晶显示控制器的相关问题

请问手机专用的液晶显示控制器的生产厂家有那些? 这些液晶显示控制器是否带标准字库?谢谢!!!…

查看全部问答>

WINCE PPP 串口直连的拨号问题

为了实现通过一根串口直连线 使 WINCE 可以拨号到 PC我的设置如下 PC主机端设置流程: 控制面板→网络连接→建立新连接→设置高级连接→直接连接到其他计算机→主机→此连接的设备(作为服务器端的COM1)→串口设为384000bps, 无流控,8位数据位 ...…

查看全部问答>

关于是否需要网卡驱动的问题

如果我的嵌入式设备不需要上网,只是下载操作系统和EVC程序,那么定制操作系统时需要添加网卡驱动吗? 因为我对同一个板子使用不同的网卡驱动或者根本不添加网卡驱动也可以把EVC程序导进去。我真的怀疑,如果 不需要上网,根本就不需要添加网卡 ...…

查看全部问答>

很郁闷的问题,谢谢大家帮忙,马上给分!!!

VxWorks的中断服务程序(ISR)运行在特定的空间。不同于一般的任务,中断服务程序没有任务上下文,不包含任务控制块,所有的中断服务程序使用同一中断堆栈。 ISR中不能调用可能导致blocking的函数,例如: (a)不能以semTake获取信号量,因如果该 ...…

查看全部问答>

今天拿到万利的ST32EK的板子,下面是我的评论。

首先: ST32EK这板 肯定可以玩起来的。即使没有任何技术支持。即使万利倒闭了也无所谓。转入正题:万利是不是在推广STM32?如果是,哪只可以说 ST找错人来帮他推STM32了!万利网站关于STM32的资源简直就是国际玩笑! 连&nb ...…

查看全部问答>

xilinx cordic ip 核 仿真时遇到的问题

我用cordic 核实现开方功能,但是用modelsim  仿真的时候输出一直是蓝线,提示很多很多warning # Loading work.sqare_test_tb # Loading work.square_test # Loading work.square # Loading D:\\X\\ISE\\verilog\\mti_se\\XilinxCore ...…

查看全部问答>