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

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

3天内不再提示

关于硬件工程师之路上的8个软件分析和发展之路

华秋商城 来源:djl 2019-09-02 15:30 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

嵌入式系统设计不仅要了解硬件还应该了解它与软件之间的相互影响和作用。硬件设计需要一定的设计范例,这点对于软件设计却不那么适用。如何从单纯的硬件设计过渡到硬软结合的设计,在你着手开发软件时需注意以下八个软件设计技巧。

1、设计控制流程图

工程师进行到开发软件这一步时会情不自禁地开始书写代码。这种思维定势就像在原理图还未完成之前就开始尝试画PCB。当着手开发软件时,克制写代码的冲动,取而代之的应该是软件流程结构图表的设计,这点非常重要。

流程图能清晰地呈现给开发人员软件的各个需要的组成部件,正如电路图列出硬件设计所需的各种元器件一样。做到这点能很大程度上使程序整体更易于组织,而且也会减少占开发周期较长的调试工作量进而节省时间减少调试的繁琐。

2、使用状态机控制程序流程

状态机是20世纪优秀的软件发明之一。应用程序一般被分解为多个不同的状态,每一个状态控制一个特定的程序分支。状态机包括内部状态和依据不同激励所控制的状态转换。使用状态机机制设计软件能够使模块化的可维护的软件开发更加容易而且易于理解。状态机原理与算法的示例随处可见。

3、避免使用全局变量

在过去的函数式编程中,程序员使用函数编写程序,他们的唯一目标是使程序尽可能快的运行而不考虑程序的结构和重用性。这类程序风格在使用全局变量时不注意变量的作用范围引起其他函数修改的危险性。这样变量会被多次占用和重写。如今面向对象的程序设计中,成员变量被定义在最小的作用范围之内并封装起来避免被重新复值和滥用。所以建议尽量少地使用全局变量,实在需要的话,使用C语言中的关键字“extern”来修饰。

4、充分利用模块化的设计理念

如果你问一位工程师项目的哪一部分最有可能会拖延交付并超出预估时间,那答案一定是软件周期了。软件通常是复杂而且不易开发和维护的,特别是当项目应用程序集中在一个单一的文件里,或者几个结构松散的文件中时。

为了便于代码重用和软件可维护并减小软件的复杂度,强烈建议发挥高级程序设计语言模块化的特性,在程序的结构中把公用的函数分离出来作为一个独立的模块。通过这种方式可以让程序员开始创建包含有常用函数和常用的声明定义,它可以很容易的被其他的代码重用,这在以后的测试阶段不仅可以节省时间代价还能提高代码的质量。

5、中断服务事件保持简练

中断服务事件是中断处理器正在执行的程序,转而去处理触发该中断的外设的请求的一种机制。处理器响应中断请求需要大量的系统开销,具体表现在保存被中断程序的状态(入栈下条指令的段地址、偏移地址和程序状态寄存器,有时还会入栈若干寄存器的值),执行中断服务程序然后恢复中断点继续执行(依次出栈各寄存器),虽然现在的处理器速度非常快但是这种系统开销仍然需要考虑。一般来说,为了避免与主程序冲突程序员总想使中断执行时间减小到最小。这就意味着中断服务事件应该短小简单。不能在中断程序中调用函数。另外,如果中断需要处理的事件特别复杂或者需要花费较长的时间,这个时候中断服务程序应该满足最小的需求,例如将数据载入到缓冲寄存器、设置标志位,而让主程序去处理读入的数据。这样处理器的工作大部分周期都在处理程序而不是中断。

6、使用处理器示例代码测试设备

对于硬件设计,在画板之前标准的测试电路有助于工程师理解电路的特性。同样可以适用于软件设计,半导体厂商通常有测试微处理器各个部分的功能的示例程序提供工程师体验各部分是如何工作的。据此可以提前组织软件的结构并且预知在设计中的问题。提前确定在设计潜在的障碍远比在产品完成前几个小时发现问题更加科学合理。而值得注意的是厂商提供的代码通常不是模块化而且不做必要的修改是很难直接用于实际的软件中的。

7、控制函数的复杂度

在工程设计中有句俗语叫“KISS”,意思是“Keep It Simple Silly”。在处理一些复杂的任务时最简单有效的方法是把它分解成若干个简单的子任务,当任务或者功能很复杂时,人们很难留意所有的细节也很难不出错。当工程师写了一个在当时能够理解的复杂函数,可一段时间后需要维护程序了还能不能清晰的呈现出当初的设计思想这是值得考虑的。有大量的技术来衡量函数的复杂度像“循环复杂度”。经验告诉我们,函数的循环复杂度应该低于10比较好。

8、详细的文档

在激烈的软件开发竞争中关注的焦点很容易就局限在代码的书写和调试而忽略文档的编写。有时迫于压力要求写文档,开发人员通常把文档安排在项目开发的最后的一个环节集中编写。然而给代码写文档应该乘在头脑里面还比较清晰的时候比较关键,这样在后续的开发或者自己阅读注释的时候能很快的回忆起当时的设计思想。

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

    关注

    68

    文章

    20325

    浏览量

    254684
  • 半导体
    +关注

    关注

    339

    文章

    31193

    浏览量

    266317
  • 嵌入式系统
    +关注

    关注

    41

    文章

    3817

    浏览量

    133864
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    电子工程师看书的四阶段 #电子 #硬件工程师 #电子爱好者 #反转 #扬兴科技

    硬件工程师
    扬兴科技
    发布于 :2026年01月17日 17:29:53

    什么是BSP工程师

    任何软件的。BSP工程师需要结合硬件原理图修改从芯片厂商拿到的参考代码,调试板子,使板子上的操作系统能够正常稳定工作,从而提供一稳定的开发调试环境,这个过程叫做点亮板子,行话叫做Br
    发表于 01-13 06:54

    硬件工程师面试必会:10核心考点#硬件设计 #硬件工程师 #电路设计 #电路设计

    硬件工程师
    安泰小课堂
    发布于 :2025年09月23日 18:00:33

    招镶入式工程师1硬件工程师

    东莞市研生科技有限公司是一家蓝牙方案公司,主营蓝牙方案的设计开发,产品包括蓝牙BLE/4G透传/AI智能体方案开发,因公司发展需要需对外招聘嵌入式软件开发工程师,对蓝牙音频/BLE以及智能IC读卡器有三年实操经验,能单独完成项目
    发表于 08-29 02:14

    电子发烧友工程师看!电子领域评职称,技术之路更扎实

    电子发烧友的各位工程师硬件开发者们,咱们每天在平台查芯片手册、讨论电路设计难题、分享嵌入式项目经验,从调试 PCB 板到开发 AIoT 系统,靠的都是过硬的技术实力 —— 而电子领域的职称评审
    发表于 08-20 13:53

    嵌入式工程师的进阶之路

    嵌入式工程师的进阶之路 (一)初级工程师(0-3 年)核心技能: 单片机开发:STM32F103系列 GPIO/USART/SPI 外设驱动,能完成 LED 呼吸灯、按键检测、串口通信等基础项目
    发表于 08-13 11:08

    【华秋DFM】V4.6正式上线:工程师的PCB设计“好搭子”来了!

    作为深耕PCB设计检查的专业工具,华秋DFM历经多年迭代,已从最初的基础设计检查工具发展为覆盖全流程的智能制造解决方案。通过持续优化 1200+细项检查规则 ,累计服务 超40万工程师用户 ,成为
    发表于 05-22 16:07

    硬件工程师炼成之路笔记(建议收藏!)

    本帖最后由 yuu_cool 于 2025-5-20 14:11 编辑 笔记内容 内容目前分为6大章 1、常用软件及教程 2、器件 3、硬件思维 4、常用电路分析 5、
    发表于 05-20 13:40

    问,成为硬件工程师需要几只手?#硬件工程师 #YXC晶振 #扬兴科技 #搞笑

    硬件工程师
    扬兴科技
    发布于 :2025年04月25日 17:15:37

    硬件工程师手册(全套)

    §1.2.1 硬件工程师职责 一技术领先、运行可靠的硬件平台是公司产品质量的基础,硬件工程师
    发表于 04-22 15:05