51单片机程序及调试步骤实战经验

我刚参加工作的时候,用的是stc 51单片机的,51单片机不像stm32那样可以通过st-link在keil上面在线仿真。

有时候出现bug的时候,非常难找问题,要一段一段屏蔽然后测试。

在刚开始接触开发的时候,我非常不习惯用在线仿真,大概是因为没用过。

记得有一次进了一家公司做行车记录仪,用的台产GRAIN的单片机。

那时候基本上没什么资料,就一个dada sheet和demo程序。

在开发之前,老大安排了给我一个任务,就是把这个仿真环境先给搭起来。

相当于是他们原厂没有的东西,让我去搞定,这个芯片是基于Fa626TE core的32位控制器。

网上的资料太少了,光是测试搭建这个环境花了半个多月,最后还没搭建出来。

那个时候完全是懵逼状态,摸着石头过河,不知道仿真啥原理,反正网上搜到一个我就试一个。

做这个之前基本都是在做51的东西,所以对我来说太难了,加上资料又少,就是跨级打boss。

后面我有点不耐烦,就跟老大说:这个我不用仿真了,以前不用仿真照样也能把产品做出来。

后来老大思考了一下,还是希望能想把仿真搞出来,我有点崩溃,实在想不明白为何他这么固执。

当我后面慢慢接触32位的单片机多了,开发的产品多了,我才真正体会到了仿真的好处。

毫不夸张地说,用好仿真,你的开发效率至少提高3倍,这里说的不是仿真软件。

拿stm32单片机举例,用st-link+keil在线硬件仿真,不但能监控程序怎么跑的,还能监控跑过程中变量的值的变化,指针地址的变化。

用熟了你就知道,特别是做指针的应用,实在太香了,有时候指针指来指去,你的理解可能只是在自己的理论层面上,而用仿真你可以监控到指针的指向变化。

那像51这种,不能像stm32那样用st-link在线仿真怎么办?(现在51好像也有了,具体没用过)

大家别小看51单片机,有些51内核的ROM都有几十K,最终产品程序的大小并不会比stm32的小。

这种如果没仿真,那出现一个BUG,够你调半天了。

在过去的开发中,我也总结了一些经验,大家可以借鉴下。

我一般是借助产品硬件上一切能作为提示的东西,比如说:

1.数码管

2.LCD

3.LED灯

4.串口

我在开发程序的时候,第一个做的肯定是点亮一个LED灯。

点亮LED能够最快地让你验证硬件核心部分(单片机最小系统)有没有问题,

点亮以后,我再开一个定时器它每秒闪烁1次,直到产品大多数功能完成。

这样做的好处就是可以验证你程序有没有跑着跑着死机之类的问题,如果有,那就及时解决,不然后面程序大了找起来会更难。

如果有数码管和LCD,调试起来会更加得心应手,直接在数码管和LCD上显示要调试的数据即可,虽然没仿真这么方便,但是总比都没有好。

还有就是串口,一般硬件在第一次打板的时候,我都会把串口预留出来,方便调试,特别是做物联网产品,串口调试可以说是必备的。

主要作用就是用来监控MCU和WiFi模组之间的通讯数据。

最后,还有一种情况就是产品啥都没有,连LED都没有,这种情况该怎么办?

这种情况就只能听天由命了,完全靠你的开发经验。

一般第一板硬件设计成这样的,都是初级水平工程师,经验不足。

即便你产品用不到那些资源,好歹把串口或者LED预留出来,把整体功能调试完以后最终一板把它去掉不就行了?

单片机原创干货

来!单片机项目实战培训第五期招募开始啦!!

2021-6-22 0:36:45

单片机原创干货

低学历学什么技术有前途可以月入过万?

2021-6-22 21:19:14

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索