专栏中心

EEPW首页 > 专栏 > 断言不是错误!

断言不是错误!

发布人:鱼鹰谈单片机 时间:2022-01-21 来源:工程师 发布文章

断言机制估计很多道友都用过,在 ST 的标准库中,经常可以看到它的身影:

1.png

它的实现方式也是非常简单的,就是通过 USE_FULL_ASSERT 宏进行控制:

2.png

如果断言失败,就会执行 assert_failed 函数,一般实现函数如下:

void assert_failed (uint8_t* file, uint32_t line)

{

  static char buff[128];  

  sprintf (buff,"%s,%d", file, line);

  __breakpoint(0);

}

当然这里的 sprintf 函数也常常使用 printf 代替,这样就可以直接通过串口打印出来了,而鱼鹰这个在没有串口的情况下,可以通过内存 buff 显示出来,比较方便在线调试。

而 __breakpoint(0) 一般由死循环 while(1) 代替,而鱼鹰觉得 while(1) 不够好,因为断言失败后,可能很久你才能发现而进入该死循环,而使用  __breakpoint 可以让你在 在线调试 模式下,立刻停止程序运行,从而可以快速定位问题。

不管哪种实现方式,断言失败的结果一般只有暂停程序了,类似 linux 内核的 panic 。

而这是设计者希望看到的,但有些开发者认为不应该这样,因为程序一旦死循环,如果开启了看门狗,会导致整个程序复位,对于产品而言,复位是很严重的 BUG 。

“我不希望我的产品复位,所以请修改你的代码,不让他产生断言失败,可以吗?”

不可以。

断言本身不是错误,它只是发现你程序的 BUG ,进而提醒你。

断言失败,往往是很严重的问题,严重到这段代码或功能无法正常执行,所以你修改的地方应该是调用者,而不是产生断言的代码,请不要颠倒主次,否则没有从根本上解决问题。

就比如最上面的 GPIO 外设指针检查断言部分,如果调用者传入一个非 GPIO 的指针进入函数,从而产生断言失败,那么你会选择关闭断言机制还是说检查你的代码是否存在问题呢?

当然是后者。

所以,如果产生了断言失败的情况,请不要慌,不要认为这是一种错误,而应该根据断言失败的位置,定位断言失败的根本原因,而不是试图通过关闭断言的方式让程序继续运行下去,这只会让你的程序运行得更糟糕,同时也更难定位问题。

专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们

关键词: 单片机

相关推荐

瑞萨RA0单片机连载——PWM实现呼吸灯

《ATmega8原理及应用手册》

5V 单片机与5V 耐压单片机有何区别,为什么至关重要

新手必看的单片机知识

嵌入式系统 2025-04-07

功率监测与控制系统DIY——搭建环境,定时器翻转LED

MSP430 电表解决方案

视频 2009-10-16

Microchip推出集成高性能模拟外设的32位PIC32A单片机

《AVR单片机C语言库》

单片机语言C51应用实战集锦

资源下载 2007-11-21

瑞萨RA0单片机连载——面向对象编程之SHT31温度计

瑞萨单片机技术概述

视频 2011-06-13

双芯智控革命:IGBT与单片机如何重塑智能微波炉

超低功率高性能新一代产品MSP430F5xx

视频 2009-10-16

MSP430x2xx4xx系列

Microchip发布PIC16F17576单片机(MCU)系列,简化模拟传感器设计

介绍采用 nanoWatt XLP技术的超低功耗系列单片机

GD32E230F6V6实用指南:为下一个项目选择合适单片机

16位语言函数工具库

车规级MCU介绍

倾情奉献:MSP430汇编指令集(中文),详解带实例!

更多 培训课堂
更多 焦点
更多 视频

技术专区