社区首页
博客
论坛
下载
文库
评测
芯语
活动
商城
EE直播间
学院
更多
社区
论坛
博客
下载
评测中心
面包芯语
问答
E币商城
社区活动
ASPENCORE学院
资讯
电子工程专辑
国际电子商情
电子技术设计
CEO专栏
eeTV
EE|Times全球联播
资源
EE直播间
在线研讨会
视频
白皮书
小测验
供应商资源
ASPENCORE Studio
活动
2020年度中国IC领袖峰会暨中国IC设计成就奖颁奖典礼
EDA/IP技术论坛 + Workshop(2020.3.19,上海)
2019ASPENCORE全球双峰会
2019年度中国IC设计成就奖
2019国际电子产业链资源对接大会
更多活动预告
杂志与服务
免费订阅杂志
电子工程专辑电子杂志
电子技术设计电子杂志
国际电子商情电子杂志
社区每月抽奖
登录
注册
首页
专栏作家
CEO专栏
技术文库
科技头条
专栏入驻
×
提示!
您尚未开通专栏,立即申请专栏入驻
帖子
博文
用户
全部
登录
首页
专栏作家
CEO专栏
论坛
博客
E币商城
资讯
电子工程专辑
国际电子商情
电子技术设计
标题
简介
内容
作者
全部
知乎热议:嵌入式开发中C++好用吗?
大鱼机器人
2020-11-28
270浏览
0评论
1点赞
点击上方
“大鱼机器人”
,选择
“置顶/星标公众号”
福利干货,第一时间送达!
1
观点一
先说结论:
嵌入式、单片机里面C++非常好使;
C with class用来作大部分开发是完全可以胜任,如果用的好,能明显改善你的代码质量(嵌入式领域,个人不鼓励STL和模板,这个后面再说)。
只有5千行代码的GuiLite是嵌入式、单片机中常用的GUI框架;它就是C++编写,在GitHub有4.8K star,在Gitee有2K star。可能你觉得5千行能做什么?
它不仅可以作常规的界面元素,还能在单片机平台上进行3D操作、可以与网页结合,把界面效果用网页的形势表现出来,当然也支持VR特效、最近还与FFmpeg集成,可以无依赖的支持视频播放。多说无益,有图为证:
这里不是说GuiLite多强,而是想说明C++语言的魅力,如果没有使用C++语言,而用C的的话,至少需要几万行才能实现相同的效果;还记得著名的爱因斯坦bug方程吗?代码多一点点,bug数量就会显著增加。
其实GuiLite就是典型的C with Class;相信很多同学觉得这很低级,但这正是C++语言发明的初心。
这种特性让你完全告别的了函数指针;当然很多C的高手,就是用函数指针实现了C++的所有特性。
首先为高手点赞,但作为普通韭菜的我们要明白它的代价就是一大堆函数指针;
只要函数指针的大量存在,代码的可读性就大大降低,而C with Class就能用最优雅的方式消灭所有的函数指针,虽然你觉得它很low,但它就能让你的代码量大大缩小;
而且它对编译器的支持极好,任何单片机编译器都能支持这种简单的C++特性。
如果你还读过Linux的虚拟文件系统代码,请问是什么反复打断你领会代码含义?
答案是函数指针,为了实现对多文件系统的支持,Linus可是在拼命的往代码里面使用函数指针。而如果选择用继承,虚函数来实现,其代码就可以大大简化。
这就是用C实现派生,虚函数扩展的代价;你可能会说:Linus这种方式效率高呀!
答案是:不存在;无论你如何在C语言层次做优化,都没发跟编译器层次的优化相提并论。
作为开发者,编程思想远远比语法糖重要的多。C with Class是编程思想的进步,虽然在语法难度上面它不值一提。
记住,我这里说的是编程思想,即使这么简单地语法,现在还是被滥用了,完全不考虑实际需要,上来就是一个class,完全不顾及class发明者的初衷。class需要你在高level重整代码结构,但你却用它污染每一个细节,每一行代码。
还是那句话,用的好,5千行就能解决很多问题;用的不好,还不如不用,还是用你最擅长的语言去污染你的代码吧,这样污染的更有效率,对吧?
最后,STL,模板适合嵌入式吗?个人觉得不大适合,首先这是对编译器的极大挑战,windows,linux平台不是问题,但在单片机环境可能存在兼容性的问题;
另外,模板,STL对调试非常不友好,不太适合运行成本(步骤)相对复杂的嵌入式、单片机开发环境。
STL,模板的发明初衷也不是为嵌入式,单片机准备的;所以,强行使用,会给你带来很多麻烦。STL,模板的最佳使用环境是大型“游戏”。
这套东西是典型用空间换时间的产物,很多牛逼的游戏所需的cpu,内存资源极少,就是他们的功劳,但代价是你的代码会比较庞大,没有1T的硬盘,就不要玩游戏了吧~~~STL,模板为什么能在游戏行业里面如鱼得水呢?
首先,运行效率很高,这里不再赘述;其次,则是游戏的重复性太高,大家回忆一下,DOTA,英雄联盟,王者荣耀在玩法上面是不是很相近呢?
正是因为相似性太高,代码重用就显得非常必要,否则游戏工业化的效率就很低,现在之所以半年就能出一款大型游戏,我说这是STL、模板的功劳,你信吗?我说是游戏引擎的功劳,你信吗?我说游戏引擎跟STL、模板是你中有我,我中有你,你信吗?
总结一下,C++编程思想对嵌入式开发者很有帮助,直接效果就是能大幅度降低你的代码量和逻辑复杂度;
STL,模板原则不适合大部分嵌入式使用环境,因为嵌入式软件的特殊性往往超过通用性,代码复用的需求不强,但只要你知道它们是为什么而生的,就会为它们选择合适的使用环境。
2
观点二
单片机的主流编译语言可预见的长期仍然是C和少量汇编的结合体,而嵌入式Linux领域的未来在我看来更倾向于多语言范式的混合应用编程,内核模块使用C,应用层逻辑使用C++, Python, nodejs的混合编程,而界面的话使用java和QT/C++,下面说原因。
在单片机领域C++不太流行既有历史原因,也有工业界的需求,对于单片机是从51发展到现在,主流的flash容量仍然在64KB~256KB左右,目前的容量限制注定了C++中的模板,泛型编程和STL等很难被运用到开发中,但如果不使用这些,只使用支持class的C++,在C语言是有结构体+函数指针可以替代的情况下,从C换成C++并没有迫切的需求,而python和js的推广困难,也有着类似的理由,此外在加上调试困难。
不过对于rust,这个理由是不存在的,但是因为历史的惯性,目前行业内无论大小公司,都大量的遗留和正在做的都是C语言项目(包含原厂的方案),替换成rust就是商业成本问题,而不是语言问题(在我看来rust语言层面优于C太多),所以rust热爱者们应该是多去为各主流厂商平台提供开源项目(具体项目,不是移植跑个hello world就完事了, 能跑和能用在产品中是两个概念),而不是呼吁语法层面多优秀。
另外单片机优势不仅仅是实时可控,而是价格便宜,对于出货量十万甚至上百万的设备,flash容量也是可观的成本,所以工业界更希望是用最小的成本做最多的事,从这方面来说,C是比C++,python, js有明显优势的。
在嵌入式Linux领域, C++绝对是应用层主力之一,QT/C++虽然目前因为芯片性能的提升,逐渐被Android/Java所替代,但仍然在医疗,工控,车载导航等领域占据主流地位,而且这也是目前C++的重要应用领域之一,说嵌入式比较难,而C++也十分困难,所以嵌入式人员学习C++比较少是十分片面客观的印象。
另外C++难的地方是移动语义,模板偏特化,lambda, 模板元编程等知识,C++各种语法组合成的奇淫巧技如果不花大量时间去钻研,看起来是犹如天书(很少有人例外),但对于工业界,特别是嵌入式类应用来说,只使用STL封装的vector,map以及算法等方便开发,封装些模板函数或者类帮助复用,很多时候C++11的新特性都用不全,说困难就有点夸大其词了。
工业界的难点永远是如何把产品的需求转换成具体的任务分解(满足性能,成本和功能的平衡,同时能够长期稳定性),而不是使用何种语言来实现任务,当需求导向任意语言,无论是python,js,C++还是java,面向工资编程,只要有需求,总会有人会踏入这个方向,难度不是问题,需求和薪水才是问题。
3
观点三
现实情况是:C++太难了,嵌入式人才本来就少,你还要能用C++且不出幺蛾子,那就更少。所以用C确实是主流。因为C程序员要求还是低些。
记得我当初刚搞嵌入式的时候,系统连MMU都没有,整个系统所有代码全都在一个内存空间,还得自己管理内存池避免内存碎片。随便一个内存访问错误可以影响到完全不相干人的模块的代码。这种系统你敢用C++?
结论:
如果你是自己一个人开发代码,并且对自己的C++水平有信心,那么用C++当然没有问题。但是考虑到整体程序员群体的C++水平以及C语言水平,用C做嵌入式项目会更现实一些。
4
观点四
第一点,
作为一个嵌入式十多年老手,可以说CPP太复杂,语言特性太多,实现一个功能能能用几十个以上的方法,太多稀奇古怪的方法去实现一个功能,CPP特性复杂得没有5年以上经验别想用好。但一个项目组几个人CPP能力不一致,用一些稀奇古怪的特性去实现一些功能,多个人之间就没法维护了。
第二点,
在调试的时候,面向对象的调试最好上图形界面的工具才好调试,而嵌入式大多数时候是没有这种调试工具的,CPP写业务,后期bug调试也会搞死你,CPP嵌入式调试比C复杂一个数量级以上。
第三点,
C语言特性虽然少,但完全够用,实现一个功能方法不会很多,1年左右入门,3年老手,而CPP3年连CPP特性还没搞清楚。C可以简单用,也可以复杂用,C with class小cass,结构体加指针轻松实现,看看linux kernel, 看看内核头文件,结构体,宏各种精妙用法,你就会发现CPP完全多余了,CPP死于复杂。有经验的大公司团队使用CPP都是使用CPP的一个子集,只使用一部分特性。
CPP设计特性太多不是优点,而是缺点,别看什么特性几乎都支持,其实太多选择其实就是没有选择。实现一个功能有且仅有一种方法才是一个好语言,例如python,go也不错。
第四点,
产品应用层其实重要的是业务,各种复杂的业务逻辑,语言特性太多反而会混乱业务逻辑。C完全够用,各种设计模式,C也可以实现。
能吸收内核一些优秀特性,例如内核双向链表,一些结构体,宏,日志,内存管理,线程管理,线程间进程间通讯,各种锁基本都需要C自己封装套来用,这些东西学会了才能说用好了C。即使对于新手来说,不会这些高级C用法,有一个高级C也可以带领一群低级刚入门的写一写业务代码。而一个高级CPP没法带领一群刚入门的CPP初学者完成同样的项目。
第五点,
资源限制,效率限制,同样的业务功能,C的内存占用,速度高于CPP,这些东西CPP里面基本都有现成的,可是了体积大,依赖多,对于嵌入式环境来说太过于笨重了。就是说同样的产品,使用C可以使用更低端的主控芯片,更小的内存,产品bom成本比使用cpp低,产品竞争优势远高于使用cpp的。
-END-
|
整理文章为传播相关技术,版权归原作者所有
|
| 如有侵权,请联系删除
|
往期好文合集
干货 | 嵌入式系统软件架构设计
嵌入式行业真的没有前途吗?
干货:嵌入式系统设计开发大全!(万字总结)
最 后
若觉得文章不错,
转发分享
,也是我们继续更新的动力。
5T资源大放送!
包括但不限于:
C/C++,Linux,Python,Java,PHP,人工智能,PCB、FPGA、DSP、labview、单片机、等等
!
在公众号内回复「
更多资源
」,即可免费获取,
期待你的关注~
热议
开发
C++
1
免责声明:
该内容由专栏作者授权发布或转载自其他媒体,目的在于传递更多信息,并不代表本网赞同其观点,本站亦不保证或承诺内容真实性等。如若文章内容侵犯您的权益,请及时联系本站删除。侵权投诉联系:
nick.zong@aspencore.com
!
大鱼机器人
一个专注于机器人技术,单片机,嵌入式系统,智能家居,智能设备,PCB设计,IT最新动态的自媒体。此外,还有海量学习资源等你来领取。作者:张巧龙,个人微信号:well_xiaolong。欢迎关注公众号,名称:大鱼机器人,公众号ID:All_best_xiaolong
进入专栏
评论
暂无评论
请登录后参与评论回复
登录
热门推荐
【小调查】您对这几个领域的半导体厂商知多少?
当您想到有汽车电子产品及专长的半导体公司,您会首先想到哪几家公司? 当你提到物联网产品的半导体公司,您会想到哪些公司?
突发!小米、中微半导体等9家企业遭美国制裁!
1月15日,据路透社消息,美国政府14日将9家中国企业列入所谓“与中国军方相关”的黑名单中,其中包括中微半导体、小米及飞机制造商中国商飞! 据悉,这次拉黑,和中芯、华为被加入“实体清单”还不太一样。路透社称,根据相关投资禁令,美国投资者需在今年11月11日前出售所持“黑名单”公司的股份。 此次被列入黑名
SMTJS资讯
2021-01-15
1163浏览
小米等9家企业被列入美国军工企业清单,后续影响更值得关注!
来源:美国国防部 1月14日美国国防部发布新闻,根据1999年国防授权法案将九家中国企业列入了其“军工企业清单”。涉及到的中国公司分别是:中微半导体设备有限公司、箩筐技术公司、小米集团(小米科技有限责任公司)、北京中关村发展投资中心、广东高云半导体科技股份有限公司、大新华航空有限公司、中译语通科技股份有限公司、中国航空集团有限公司、中国商用飞机有限责任公司。
芯世相
2021-01-15
785浏览
正式通知:支付宝/微信/京东再也不能存款了!
出品 21ic中国电子网 付斌 网站:21ic.com 此前,网络巨头纷纷主动下架存款产品,分析人士预计,后续监管部门或将针对互联网存款出台专门的监管办法。日前,正式条款正式到来,这也说明未来阿里支付宝、腾讯理财通/微信、京东金融等平台,再也不能销售曾经火爆的互联网存款产品了…… 1月15日,中国银保监会和中国人民银
21ic电子网
2021-01-16
592浏览
又出事了!继失火断电之后,这次轮到雪灾了……
出品 21ic中国电子网 蔡璐整理 网站:21ic.com 日前,21ic家在 《突发!又一晶圆代工厂断电罢工,产能更吃紧了》 一文中报道了联电突发断电事故,导致8英寸晶圆产能缺口或将进一步扩大。 随后的1月13日,华新科电子位于广东东莞的核心工厂又传出了失火的消息,这使
21ic电子网
2021-01-15
484浏览
上汽集团、张江高科和阿里巴巴集团联合打造智己汽车
由上汽集团、张江高科和阿里巴巴集团联合打造的智己汽车,于中国上海、美国拉斯维加斯CES和英国伦敦三地同步发布:高端智能纯电动汽车品牌-IM智己,全新诞生。秉承「我自由我」的品牌主张,IM智己将在人工智能的伟大时代,与用户共生,定义智能时代汽车该有的样子,成就「智能时代出行变革的实现者」。 IM智己全新量产定型车 IM智己我自由我 中文品牌名「智己」,
美通社头条
2021-01-19
470浏览
享众测:京东自产羊毛速速来薅,1分钱包邮买蓝牙耳机、口罩、生活用品等等
测评1分钱买的蓝牙耳机,感谢京东和深圳的黑科技 最近买了个蓝牙耳机,1分钱而且还包邮。可能很多玩家笑掉大牙,1分钱能买买什么,买个耳机线都买不了,哪怕买到蓝牙耳机估计也是个废物。 笔者刚开始也是这样认为的,不过拿到
享众测
2021-01-15
383浏览
C代码与C++互相调用的小技巧
关注+星标公众号,不错过精彩内容 转自 | 嵌入式情报局 1C与C++相互调用 在
strongerHuang
2021-01-16
330浏览
吉利、京东、富士康、字节跳动、英特尔、金沙集团等公司高管变动
一周企业高管变动要闻。 中国 浙江吉利控股集团有限公司法人1月15日发生变更,原法人代表李书福卸任,由浙江吉利控股集团CEO李东辉接任。同一天,李书福还卸任吉利科技集团有限公司法人代表,由其CEO徐志豪接任这一职务。卸任这两家公司法定代表人后,李书福仍然是两家公司的控股股东和董事长。李书福的持股比例分别为91.0753%和90%,另一股东为李星星,即李书福的儿子。
美通社头条
2021-01-18
296浏览
相关推荐
全年净销售额超千亿!光刻机巨头ASML 2020全年多项业绩优于预期
综合报道
2021-01-20 19:44
24浏览
2021:uCPE年?
Tomas Hedqvist,产品行销总监,Enea公司
2021-01-20 18:04
8浏览
特斯拉model3发生自燃并爆炸,官方回应来了
综合报道
2021-01-20 17:43
192浏览
低功耗蓝牙SoC利用达角(AoA)定位技术增强IoT资产管理
2021-01-20 17:34
6浏览
面向接入设备的恩智浦Wi-Fi 6E三频段芯片组释放6GHz频谱的潜能
2021-01-20 17:27
9浏览
晶瑞股份购买ASML XT 1900 Gi光刻机进厂,用于多少纳米分辨率光刻胶研发?
刘于苇
2021-01-20 17:20
33浏览
“数字化”是大势所趋,企业如何重塑供应链?
李晋
2021-01-20 17:03
44浏览
隔着屏幕的CES还能吸引消费者吗?
Rebecca Day,EE Times专栏作者
2021-01-20 16:02
55浏览
大鱼机器人
一个专注于机器人技术,单片机,嵌入式系统,智能家居,智能设备,PCB设计,IT最新动态的自媒体。此外,还有海量学习资源等你来领取。作者:张巧龙,个人微信号:well_xiaolong。欢迎关注公众号,名称:大鱼机器人,公众号ID:All_best_xiaolong
文章:664篇
粉丝:53人
关注
私信
最近文章
2020年电赛题目,命题专家权威解析!
掌握AI核心技术没有秘籍,能自己创造就是王道
2020年电赛题目,命题专家们怎么看?
PCB元器件摆放不可忽略的10个技巧
热门文章
电感为什么会啸叫?漫画+动图,看完就明白了!
C语言 main 函数到底为啥这么写?
在华为,加班究竟有多恐怖?
【深度好文】过了30岁,做技术开发、工程师还有前途吗?
推荐
机电一体化设计中的 ECAD - MCAD 协同设计过程
如何布署智能城市– 智能路灯
免费样品,一键申领!电子开关、连接器…
【纳安咨讯】组建“千亿广电”为了啥?
广告
热门资料
热门帖子
热门博文
1
Altium Designer实战攻略与高速PCB设计 [黄杰勇,林超文编著][电子工业出版社]
2
技术资料-PCB设计规范
3
开关电源的经典培训
4
射频知识
5
PCB板设计中的接地方法与技巧
6
概率论与数理统计
7
深度学习
8
芯片封装测试流程详解
9
《51单片机C语言程序设计教程》 王云完整版
10
开关电源维修从入门到精通
1
辞旧迎新,贺新年得红包!“写春联”活动又来了!
2
【话题讨论】全球晶圆短缺,国外“芯”纷纷涨价、缺货,各位朋友,你们公司准备导国产“芯”了吗?
3
【话题讨论】小米11值得购买吗?
4
【话题讨论】新时代的工程师都需要修炼哪些必备技能
5
【新年互动话题 —— 请回答2010】电子人生,回望我的十年
6
【话题讨论】小米11——GaN充电器白送?
7
【话题讨论】在AIOT时代,你会在自己项目上用国产操作系统吗?
8
【原创】使用Python制作飞机类小游戏
1
脚踩智能汽车春风,百度踏上千亿美元市值征程
2
基于CPCI总线连接的国产化主板
3
RT-Thread隐藏的宝藏之completion
4
高精地图开启量产博弈
5
MPO/MTP光纤跳线十大应用场景
6
嵌入式面试题,不断更新
7
年度总结 | 2020年新能源汽车销量排行榜
8
cmake的安装过程
在线研讨会
EE直播间
产业分析系列— 千亿级规模的5G毫米波离我们有多远?
直播时间:03月12日 10:00
市场分析系列—2021年Q1采购调查及2021大热点应用趋势展望
直播时间:03月25日 10:00
产业分析系列—Cat.1 与 NB-IoT
直播时间:04月09日 10:00
产业分析系列—图像传感器用于 AI 计算
直播时间:05月14日 10:00
热门标签
更多>>
半导体
通信网络
消费电子/手机
汽车电子
物联网
工控
硬件设计
嵌入式/FPGA
电源/能源
测试测量
人工智能/机器人
科技前沿
供应链
工程师职场
分享到
评论
0
点赞
1
我要评论
0
1
分享到微信
分享到微博
分享到空间
点击右上角,分享到朋友圈
我知道啦
请使用浏览器分享功能
我知道啦