资料介绍
软件工程师:我今天要完成xx行代码的重构
硬件工程师:这几个器件能不改就不改,实在不行用独家供货
软件的灵活性很高,可以根据需要进行修改,即使是微不足道的修改,只要能让代码看起来比较“爽”,都可以随时进行调整。况且现在代码的版本控制工具比较成熟,实在不行可以用时光机返回所有的修改。
硬件不一样,有时候动一根线,或者layout的时候动了一点位置,都可能导致信号产生比较大的噪声或者异常。每一个器件的修改也是慎之又慎,需要一系列替代测试和可靠性测试,即使是在风险可控的条件下,也要考虑投入产出比。
软件工程师:有一个新的需求,我们要考虑一下实现方案
硬件工程师:有一个新的需求,我们看能不能在原来的方案上改一改
软件行业日新月异,有各种各样的语言、框架和实现方式,程序员的经验可以让他们更快的学习,但因为时常要面对新的东西,随着年龄的增长会显得力不从心,于是就有了程序员吃青春饭的说法。同时,由于软件的灵活性,需求往往是变化多端的,即使是在同样的框架下,面对各种各样的需求也有可能遇到很多坑。
相对软件行业,硬件的变化算是比较小的,虽然性能可能在不断提高,但更新的速度和更新的范围往往是较小的。经常是用着100年前的原理,加上20年前的技术,改一改实现新的需求。因此有了硬件人员的经验论,当他对需要的一些器件了如指掌的时候,制定方案或者定位问题都是完全可控的,而这些器件在他有生之年可能都不会有突飞猛进的变革了,依靠之前积累的经验就可以让他游刃有余。
软件工程师:It works!! 好吧,就这样搞定吧。
硬件工程师:换了一个电容就可以了,不科学啊,我得找下是什么原因
遇到问题的时候,硬件工程师比较倾向于“根因分析”,所有现象必须要有个解释,这样的话可以减小问题重犯的概率。如果问题不彻底解决,往往代价是很高的。软件工程师往往觉得问题解决了就是OK的,后面还有一堆的需求和变化需要处理,有时间再去分析一下。这里不一定是责任心的问题,一个原因是因为再次遇到问题的代价不一样,另外有时候是因为需要管理的复杂度。
硬件面对的复杂度从某种程度上说是有限的,也就这么几个器件,遇到问题顺藤摸瓜就行了,大不了还有定位的必杀技——“替代法”,每个器件换一遍,大概就能找到问题所在了。软件面对的复杂度相对较大,如果涉及到操作系统甚至还需要hack操作系统,如果几个模块是由多个工程师开发的,模块之间的耦合度又较高,定位问题显得心有余而力不足。
软件工程师:我的代码是一颗树,我要每天去耕耘
硬件工程师:我的方案是一个平台,以后的需求就在这个平台上面改一下就好了
“平台化”对双方来说看起来都是非常不错的,面对新的需求只要在上面修改一下就好了,领导尤其喜欢这种理想状态,可以作为管理绩效的体现。根据上面说明的复杂度和需求变化的程度而言,软件的平台化往往只是个开始,就像是栽下了一颗树苗,后面的路还很长。这其中发挥比较重要作用的往往是软件工程师本身,而不是硬盘里面的那些可能不成熟的代码。
软件工程师:项目节点要到了,实在不行我先发布一个beta版本
硬件工程师:项目节点要到了,实在不行只能延期了,争取后面不再修改
iPhone 每一个机型的升级需要一两年的时间,而iOS却似乎每个月都在更新。对于互联网行业的软件尤其如此,似乎每时每刻都在升级,像google的很多产品一直处在beta的版本,有的甚至生命周期都结束了,都还挂着beta的标签。升级成本和开发周期的不一样,使得双方面对项目时间点的态度会有所不同。
软件工程师:在我那边还好好的,怎么到你这边就不行了
硬件工程师:这个现象也是可以解释的,可能是米勒电容/寄生电感/xxx的影响
程序运行起来之后一般都是很老实的(不老实会被狗咬死),CPU 忠实的运行着每一条指令,虽然在它的世界里面只有0和1,但绝不会出现1+1不等于2的情况。虽然很有可能是程序员自己没有考虑到的场景,但他常常会找运行环境或者操作方面的“借口”。
硬件系统不一样,一样的布局布线,也有可能因为器件之间的微小差异导致运行的问题,而器件本身不是完全理想的,经常会出现1+1=2.1的情况。因此硬件工程师需要保持对这些微小差异的敏感度,去解释这个混沌的世界。
软件工程师:再安排一次检视,想想看还有没有什么场景可能导致问题
硬件工程师:再多做几个模块,确保方案的可靠性
测试不管对软件和硬件来说都是有效的可靠性保障,但测试的理念还是有不一样的地方。硬件测试对重复要求较高,很多器件可能跑着跑着自己就悲剧了,比如电解电容在高温环境下一段时间后电解液减小的较多。因此对同一个模块的反复测试,或者同一种场景的反复测试是很常见的,极端情况就是所谓“高温高湿”实验,加速器件的老化。
而软件系统由于其运行的一致性,更多是考虑测试覆盖度,尽量去覆盖每一种场景,甚至每一行代码。测试覆盖不到的,就使用人海战术,通过人每一行代码的检视,去发现可能的问题。
结 语
不管软件工程师和硬件工程师有多少差异,他们都在通过自己努力在一点一点改变着这个世界。也希望自己能在若干年之后,还能自豪的称自己为程序员,一个略懂硬件的码农。
来源:嵌入式资讯精选
(mbbeetchina)
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 做一个可以跟随光线的机器人
- 用3行代码做一个WebServer
- 用LDR做一个自动夜灯
- 一个脉搏血氧计的设计示例资料下载
- 6个方面。嵌入式的硬件构架资料下载
- 优秀的硬件工程师设计一个产品会考虑哪些方面资料下载
- 设计硬件电路到拿到板调试,是怎样一个过程资料下载
- 嵌入式硬件研发的8个阶段资料下载
- 一个MCU项目问题的硬件软件分析资料下载
- 做一个电线断线断点检测器,原理是什么?资料下载
- +:和-:符号,Verilog标准文档中的一个语法资料下载
- 16位CRC验证码生成VI工具下载 57次下载
- 使用单片机做一个简单的流水灯的程序和烧写资料免费下载
- 使用51单片机制作的做一个简易时钟程序免费下载
- 使用51单片机做一个简易呼吸灯的程序免费下载 1次下载
- 功德+1,用小安派-Eyes-S1做一个电子木鱼 867次阅读
- 如何用小安派-Eyes-S1做一个电子木鱼? 2k次阅读
- 使用FPGA做一个ODrive 1.9k次阅读
- 鸿蒙上做一个loading加载动画 6.1k次阅读
- 自做一个红外控制装置,控制家电很简单 2.8k次阅读
- 为鸿蒙小车做一个遥控器 1.8k次阅读
- 如何确定一个硬件加速应用 987次阅读
- 译码器:做一个简单的六进制技术电路 9.2k次阅读
- 机器码怎么改 1.9w次阅读
- 详细介绍RFID身份码发射器硬件设计方案 1k次阅读
- 以一个真实网站的验证码为例,实现了基于一下KNN的验证码识别 8.5k次阅读
- 如何用旧手机做一个个性十足的音箱? 3.3w次阅读
- 如何用废弃的电脑风扇做一个磁搅? 7.3k次阅读
- 对正极材料的检测方法做一个初步的介绍 1.2w次阅读
- 对有关IC设计流程的相关事宜做一个总结 1.7w次阅读
下载排行
本周
- 1矽力杰 Silergy SY7215A 同步升压调节器 规格书 Datasheet 佰祥电子
- 1.12 MB | 5次下载 | 免费
- 2HT81696H 内置升压的30W立体声D类音频功放数据手册
- 1.21 MB | 1次下载 | 免费
- 3HTA6863 3W超低噪声超低功耗单声道D类音频功率放大器数据手册
- 0.87 MB | 次下载 | 免费
- 4南芯 Southchip SC8802C 充电控制器 规格书 Datasheet 佰祥电子
- 88.16 KB | 次下载 | 免费
- 5矽力杰 Silergy SY7065 同步升压转换器 规格书 Datasheet 佰祥电子
- 910.67 KB | 次下载 | 免费
- 6矽力杰 Silergy SY7066 同步升压转换器 规格书 Datasheet 佰祥电子
- 989.14 KB | 次下载 | 免费
- 7WD6208A产品规格书
- 631.24 KB | 次下载 | 免费
- 8NB685 26 V,12 A,低静态电流,大电流 同步降压变换器数据手册
- 1.64 MB | 次下载 | 2 积分
本月
- 1EMC PCB设计总结
- 0.33 MB | 12次下载 | 免费
- 2PD取电芯片 ECP5702规格书
- 0.88 MB | 5次下载 | 免费
- 3矽力杰 Silergy SY7215A 同步升压调节器 规格书 Datasheet 佰祥电子
- 1.12 MB | 5次下载 | 免费
- 4氮化镓GaN FET/GaN HEMT 功率驱动电路选型表
- 0.10 MB | 3次下载 | 免费
- 5PD取电芯片,可取5/9/12/15/20V电压ECP5702数据手册
- 0.88 MB | 3次下载 | 免费
- 6SY50655 用于高输入电压应用的伪固定频率SSR反激式稳压器英文资料
- 1.01 MB | 3次下载 | 免费
- 7怎么为半导体测试仪选择精密放大器
- 0.65 MB | 2次下载 | 免费
- 8SY52341 次级侧同步整流英文手册
- 0.94 MB | 2次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935137次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420064次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233095次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191469次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183360次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81606次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73832次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65991次下载 | 10 积分
电子发烧友App





创作
发文章
发帖
提问
发资料
发视频
上传资料赚积分
评论