C语言中用ASSERT调试的八大技巧技巧1:记住ASSERT的定义
对许多开发人员来说,断言是一个令人困惑的话题,因为它们的许多使用方式与其设计初衷背道而驰 。我见到的最清晰的断言定义是这样的:
“断言是在程序某个特定点的一个布尔表达式 , 除非程序中有缺陷(Bug),否则它的值将为真 。”
想要理解上述断言定义的开发人员应该留意下面三个要点:
·断言会评估一个表达式是真还是假
·断言是在代码中的某个点对系统状态的一种假设
·断言会验证系统假设,如果不为真,就表明代码中有一个缺陷
技巧2:使用ASSERT验证函数的先决条件
断言非常适合契约式设计环境 , 在这种环境中,开发人员非常清晰地定义了某个函数的先决条件 。断言可以用来检查该函数的输入是否满足先决条件 。就拿图1所示的代码片段为例:
图1:函数的先决条件
函数的STate输入应该在定义的系统状态范围内 。如果State不是有效的状态值,那么它就不是错误,而是缺陷!断言可以用来验证State是有效的假设 , 如图2所示:
图2:对函数先决条件应用断言
在State不小于最大值的事件中 , 断言表达式将被评估为假,程序于是将停止执行 。停止程序执行可以让开发人员很容易马上看到哪里的代码出错,而不是过段时间以后才知道 。
技巧3:使用ASSERT验证函数的后置条件
断言也能用来验证契约式设计环境中对某个函数输出的假设 。例如,如果前面定义的System_StateSet函数返回SystemState变量,开发人员可以预计它也在期望的范围之内 。断言可以用来对缺陷进行监视,如图3所示 。
图3:对函数后置条件应用断言
开发人员在查看上述代码后可能会感到这些检查毫无意义 。刚刚才设置好的SystemState怎么就会出现大于SYSTEM_STATE_MAX的值呢?答案是这确实不应该出现 , 然而有时候会莫名其妙地发生改变,也许是通过中断或并行线程,此时断言可以立即标志出这个缺陷 。
技巧4:不要把ASSERT用于错误处理
在记住断言定义之后,开发人员应该切记:断言是用于检测缺陷的 , 不能用于错误处理 。错误处理是设计用于响应错误的用户输入和意外的事件顺序的软件 。错误在系统中预料是会发生的,但仅仅是因为有无效的输入而并不意味着代码中有缺陷 。错误处理应该与缺陷寻找分开来 。错误使用断言的一个典型例子是,在试图打开一个文件用于读取时去检查文件的指针,如图4所示 。
【c语言中对函数没有评估 c语言中对函数没有评估的是什么】 图4:ASSERT的不当使用
读者可以清楚地看到,试图打开文件的结果与文件系统的状态和用户数据有关,而与代码中的缺陷一点关系也没有 。开发人员应该编写错误处理程序,而不是用断言,以便在文件不存在时,错误处理程序可以用一些默认可用数据来创建它 , 以便后续代码继续操作 。
技巧5:ASSERT仅对开发有意义,不能用于生产
开发ASSERT宏的原始意图是在开发过程中启用它,在后面生产时要禁用 。可以用NDEBUG宏激活和禁用ASSERT 。正确实施的断言在被禁用后应该对嵌入式系统基本没有影响 。
问题是 , 如果测试是在断言启用的情况下进行的(为了捕捉任何缺陷,应该这样做),那么现在禁用断言将导致交付的产品与测试的产品处于不同的状态 。断言确实会占用一些代码空间 , 但更重要的是,它们需要占用少量的时钟周期来评估它们的布尔表达式 。禁用ASSERT可能对具有有限资源的裸机系统的执行时序产生很大影响,从而导致在生产系统中产生新的缺陷 。开发团队需要判断是否值得冒关闭断言的.风险 。
一种替代方案是保留断言在激活状态 , 而将它们的输出重定向到一个系统日志 。这样可以确保任何挥之不去的缺陷很容易被识别,而且能避免中止系统的运行,而中止系统可不是明智之举 。
技巧6:不允许断言有副作用
ASSERT的默认实现允许开发人员包含一段可执行代码作为布尔表达式的一部分 。举例来说 , 一个状态变量可以被实现为表达式的一部分并传递给ASSERT 。但如果传递给ASSERT的表达式有副作用,也就是说,它会改变嵌入式系统的状态,那么禁用断言将改变系统的行为 。开发人员应该确保他们的表达式没有副作用,否则他们需要冒险在系统中增加只针对产品代码唤醒的休眠时间缺陷 。
技巧7:断言应该占代码的1%至3%
每个开发人员对于代码库(Code Base)中应该有多少个断言都有自己的主见 。大家一致同意的一个数字是,代码库中的断言占比应该大于0 。断言为开发人员提供了一种在代码库中发生缺陷的时刻发现它的好方法 。调试是在开发嵌入式系统中最浪费时间并令人沮丧的事情之一 。不管开发人员认可的占比是1%、3%还是5% , 使用断言肯定对你有利,并会使开发嵌入式软件变得多少有些趣味 。
技巧8:将断言用作可执行代码注释
断言可以生成极好的注释!编写出色的表达式可以确切地告诉开发人员在代码的某个给定点应该预料发生什么事情 。开发人员应该做好他们断言的架构 , 帮助人们更清楚地理解系统中发生的事情,进而帮助减少缺陷 。
小结
断言是一种出色的工具,但有太多的嵌入式软件开发人员忽视了这一工具 。本文讨论的八个技巧只是如何正确使用断言的冰山一角 。接下来读者就可以在测试平台中建立和开始使用断言,并研究它们在实际的嵌入式系统中是如何工作的 。
C语言中术语不可评估函数是什么意思你这个问题看似简单,其实涉及到了函数的声明与定义 , 以及 C语言的标准规范和具体编译器的实现问题 。
C语言中函数的类型有哪些呢?对于C语言中的函数类型,一般可以分为以下两类:
1. 库函数(Library Function):也称为内置函数(Built-in Function),是由C语言提供的、已经封装好的函数 。库函数通常具有标准化、通用化的特点,包括数学运算、字符串处理、文件操作等方面 。例如`printf()`和`scanf()`是C语言中常用的库函数 。
2. 用户自定义函数(User-Defined Function):也称为外置函数(External Function),是程序员根据需求自行编写的函数 。用户自定义函数可以将某一段需要重复使用的代码封装成一个函数 , 在其他地方调用该函数即可实现相同的功能,起到了复用代码的作用 。在需要多次执行特定任务时,使用自定义函数可以使程序结构更加清晰、易于理解 。
关于c语言中对函数没有评估和c语言中对函数没有评估的是什么的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。
推荐阅读
- 网红直播和平精英键位图,和平精英主播键位图
- wordpress媒体库,wordpress媒体库插件
- u盘什么启动系统安装系统安装程序,u盘装机启动项选哪个
- 暗黑血统动作游戏名字,暗黑血统过场动画
- oracle怎么看对象 oracle怎么看sid
- linux返回到桌面命令,linux返回快捷键
- 有魔法的即时战略游戏有哪些,魔法题材游戏
- 上海土豆直播卖货骗局,土豆直播是干啥的
- python函数笔记软件 python函数总结