0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

减少调试时间的 3 个技巧

李微波 来源:夜猫煮茶 作者:夜猫煮茶 2022-07-14 08:17 次阅读

There are a lot of potential changes that software development teams can make to decrease the time they spend debugging and get it into single-digit percentages.

工程师喜欢解决问题。这就是我们所做的。不幸的是,嵌入式软件工程师最大的问题之一是我们制造了很多问题,然后通过花费大量时间来修复它们(调试!)使自己成为英雄。嵌入式软件工程师花费 20% 到 40% 的时间进行调试的公司很常见!值得庆幸的是,团队可以做出很多潜在的改变来减少他们花费在调试上的时间,并将其降低到个位数的百分比。在本文中,我们将研究几个减少调试时间的技巧。

提示 #1 – 拥抱测试驱动开发 (TDD)

测试驱动开发是一种允许开发人员增量构建他们的生产软件的技术,他们依靠测试来指示他们编写的代码。例如,TDD 让开发人员首先编写一个测试用例,使其失败,然后只编写允许该测试用例通过的代码。然后重复该过程。

传统上,嵌入式软件开发人员会在测试之前编写整个代码模块。在几周内编写数千行代码是可能的。那么,到了测试它的时候,如果它不起作用,问题在哪里呢?只有天知道!开发人员必须煞费苦心地回顾代码并发现问题所在并修复它。执行此操作所需的时间可能相当可观。

另一方面,对于使用 TDD 的开发者来说,如果出现错误并在代码中注入了 bug,测试用例会立即告诉开发者!由于他们正在逐步编写代码,因此他们更有可能确切地知道他们所做的更改并可以立即解决问题。TDD 似乎需要更多时间来练习,但它创建了一组可以在回归测试中运行的测试用例,以确保一切都按预期工作。TDD 一石二鸟:减少调试时间和自动化测试。

提示 #2 – 尽可能多地开发脱靶

当一个项目开始时,几乎每个嵌入式软件开发人员的第一反应就是获得一块开发板并开始编写嵌入式代码。不幸的是,在许多情况下,嵌入式代码并不是我们产品的差异化因素。这是应用程序代码。虽然许多应用程序代码最终需要与硬件交互,但许多模块可以脱靶开发,即在主机上。

开发脱靶代码为开发人员提供了许多减少每个调试周期所花费时间的机会。例如,通常,要为目标微控制器编写和测试代码,开发人员必须:

交叉编译代码

启动调试会话

通过 SWD 对设备进行编程

在目标上运行代码

通过在目标上运行代码来验证代码是否正常工作(还必须具有所有低级代码)。

如果代码是在主机上开发的,开发人员必须为主机编译它,然后使用单元测试工具、仿真器或自定义程序来运行正在开发的代码。如果发现问题,修复、重新编译并重新开始会更快。在嵌入式目标上,仅对目标进行编程就会使每个周期增加几十秒,更不用说单步执行代码的诱惑了。

脱靶开发/调试可能会产生特定的错误。但是,我现在编写了大约 75% 的代码偏离目标,并且发现我的速度更快、效率更高。我可以快速强制代码中的问题,确定原因,修复它,然后继续前进,而不是通过嵌入式目标跟踪问题。当然,有些事情会出现在目标上,而不会出现在主机上。

提示 #3 – 掌握调试策略

人类已知的效率最低的调试方法是单步调试代码行。不要误会我的意思,有时间和地点,但往往会浪费很多时间。不幸的是,嵌入式软件开发人员默认使用断点和单步调试。为了更好地调试,开发人员需要掌握现代微控制器上可用的其他调试策略。

今天,至少有八种不同的调试技术可供开发人员使用。这些技术从最简单到最复杂的顺序包括:

Watch / Expressions:为开发人员提供检查 CPU 和外设寄存器的能力。它们通常可用于监视变量、执行计算或在更改时停止 CPU。

断点:为开发人员提供在特定代码行上停止 CPU 执行的能力。高级断点可用于设置条件语句。

printf:为开发人员提供将字符数据打印到映射的串行接口的能力。根据实现,这可能会或可能不会影响实时性能。

断言:这些是用于验证程序中特定点的假设的条件语句。断言失败通常会停止 CPU 并提供失败断言的文件和行位置。

Statistical Profiling:对应用程序中的各种寄存器进行定期采样,这些寄存器同时发生在其运行中。通常不会影响实时性能。例如,可能想要对程序计数器 (PC) 进行采样以了解正在执行的代码模块。

数据分析:对包含可变数据的各种内存位置进行定期采样。当与实时可视化工具一起使用来监控系统状态、感兴趣的变量变化等时,数据分析会非常有用。

任务和数据跟踪:使开发人员能够跟踪实时操作系统应用程序中的事件。因此,开发人员可以深入了解应用程序性能、任务延迟、运行时间等等。

指令跟踪:使开发人员能够记录在处理器上执行的每条指令。这可用于了解测试期间的代码覆盖率、调试编译器问题等。

掌握所有这些技术并知道何时使用它们可以大大减少当缺陷确实进入系统时用于调试的时间。

结论

可能会花费大量时间调试嵌入式软件。有时,调试时间是无法避免的;但是,在许多情况下,开发人员可能会花费比他们需要的时间更多的时间。我们已经探索了几个您可以进一步调查的领域,以减少您和您的团队花费在调试上的时间。如果您花费超过 20% 的时间进行调试,请在本周花一个小时确定您可以立即开始进行哪些更改,以控制您花在调试上的时间。

审核编辑 黄昊宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5082

    文章

    19107

    浏览量

    304833
  • 调试
    +关注

    关注

    7

    文章

    578

    浏览量

    33924
收藏 人收藏

    评论

    相关推荐

    如何调试时间继电器 时间继电器的工作时间设置方法

    1. 了解时间继电器的基本原理 在开始调试之前,了解时间继电器的工作原理是非常重要的。时间继电器通常由一输入电路、一
    的头像 发表于 12-09 10:40 246次阅读

    socket编程中的错误处理技巧

    :错误处理能够确保程序在遇到异常情况时不会崩溃,而是能够优雅地处理问题。 提升用户体验 :通过适当的错误处理,可以给用户提供清晰的错误信息,避免用户感到困惑。 便于调试和维护 :良好的错误处理可以帮助开发者快速定位问题,减少调试时间
    的头像 发表于 11-01 17:47 852次阅读

    TDA3xx ISS调优和调试基础设施

    电子发烧友网站提供《TDA3xx ISS调优和调试基础设施.pdf》资料免费下载
    发表于 10-11 10:16 0次下载
    TDA<b class='flag-5'>3</b>xx ISS调优和<b class='flag-5'>调试</b>基础设施

    通过优化补偿最大限度地减少导通时间抖动和纹波

    电子发烧友网站提供《通过优化补偿最大限度地减少导通时间抖动和纹波.pdf》资料免费下载
    发表于 08-26 11:34 0次下载
    通过优化补偿最大限度地<b class='flag-5'>减少</b>导通<b class='flag-5'>时间</b>抖动和纹波

    开发攻略之STM32调试端口的映射

    最近有一项目用到了STM32F103RB系列单片机,由于引脚数量较少,不得不使用到了单片机的PB3和PB4两引脚。而这两引脚刚好又是STM32系列的JTAG
    的头像 发表于 08-03 08:11 429次阅读
    开发攻略之STM32<b class='flag-5'>调试</b>端口的映射

    时间继电器应用的三关键点是什么?

    时间继电器应用的三关键点:选型、安装和调试。 一、时间继电器的选型 确定时间继电器的类型 时间
    的头像 发表于 06-21 10:00 770次阅读

    具备“制造意识“的超构透镜设计或可减少设计阶段到生产阶段转换时间

      融入“制造意识”(Manufacturing Awareness)的设计是一种设计哲学,它强调在产品设计和开发过程中对制造过程的理解和考虑。这种设计方法的目的是减少设计阶段到生产阶段的转换时间
    的头像 发表于 06-18 16:51 1104次阅读
    具备“制造意识“的超构透镜设计或可<b class='flag-5'>减少</b>设计阶段到生产阶段转换<b class='flag-5'>时间</b>

    谈谈EMC,工程师必须知道的58EMC问答

    1要对产品做电磁兼容设计?答:满足产品功能要求、减少调试时间,使产品满足电磁兼容标准的要求,使产品不会对系统中的其它设备产生电磁干扰。2对产品做电磁兼容设计可以从哪几个方面进行?答:电路设计(包括
    的头像 发表于 06-13 08:28 472次阅读
    谈谈EMC,工程师必须知道的58<b class='flag-5'>个</b>EMC问答

    如何有效减少PCBA的打样时间

    一站式PCBA智造厂家今天为大家讲讲PCBA加工如何减少打样时间?有效减少PCBA打样时间的方法。 如今,国内电子加工业十分繁荣,作为专业PCBA加工厂家,订单完成得越快越好,尤其是针
    的头像 发表于 06-04 09:27 315次阅读

    使用4芯M9插头可减少安装时间

    德索工程师说道在探讨使用4芯M9插头是否能减少安装时间之前,我们需要先明确安装时间的影响因素。安装时间的长短通常取决于多个因素,如连接器的设计复杂度、安装操作的难易程度、以及安装工具的
    的头像 发表于 04-17 14:44 819次阅读
    使用4芯M9插头可<b class='flag-5'>减少</b>安装<b class='flag-5'>时间</b>吗

    PLC控制系统实际调试中常见的三大问题

    用PC设计一控制系统时,一最重要的参数就是时间,PC执行程序中的所有指令要用多少时间,(扫描时间)有一
    发表于 03-08 14:06 682次阅读

    miniprog3不能调试的原因?

    这边有三MINIPROG3不能调试,可以下载程序,但是调试的话,界面卡,芯片型号出不来,不能调试
    发表于 02-18 06:20

    Arm调试架构基础知识详解

    调试是软件开发的一重要组成部分,通常是最消耗时间的(也因此非常昂贵)。错误可以是很难察觉、重现和修复的,而且也难以预料解决一缺陷需要多长的时间
    的头像 发表于 01-02 10:45 2476次阅读
    Arm<b class='flag-5'>调试</b>架构基础知识详解

    shell脚本调试技巧

    /a.txt.ori/tmp/a.txtset+x 提示: 开启调试功能通过set -x 命令,而关闭调试功能通过set +x 5、习惯 最关键的是熟练语法,编码习惯,编程思想,将错误扼杀在萌芽状态,减少调试负担,提高效率。
    发表于 12-28 16:57

    伺服电机调试和选型方法

    伺服电机的选型和调试是实现精准控制和提高工业自动化效率的关键步骤。正确的选型和调试可以显著提升机械系统的性能,减少维护成本,延长设备使用寿命。以下是伺服电机调试和选型的详尽步骤。
    的头像 发表于 12-25 14:34 933次阅读