01
话题
时常有学院生同事苦恼:我究竟是学STM32还是学嵌入式linux。
这个问题好多人还会有自己的想法,明天我试着从多个角度,把我了解到的事实讲一下,希望对你们有所启发。
02
STM32确实好
首先得承认STM32确实好,好到STM32都成了单片机MCU的代名词了,如今好多人甚至说单片机时默认就说STM32,实际上还有好多单片机的啊。
你们学点技术图哪些?
还不是为了找工作赚薪水。
其实我承认你们都有更远大的理想国内linux主机,并且即使你想造快船也得结业后先能找到工作挣钱糊口开始。
所以假如你让我学个东西都没公司要,都找不到工作,那学它肯定错了。
你不妨去各大招聘网站搜索一下,STM32相关岗位真的好多,你若果STM32玩的溜,找份工作真的不成问题。
但是大多数一二线城市都有工作机会,这一点更难得。
总结一下,学STM32肯定没错,这玩意儿起码能让你有份工作。
也就是说虽然你在工作中须要用到其他MCU,例如说NXP的LPC系列,Cypress、TI的MCU系列,而这种你从来没接触过完全不会。
然而,只要你熟练把握STM32,才能很快上手这种MCU的开发工作。
目前好多国产MCU厂商如GD、国民技术等在推出的国产MCU也是对标STM32的,在开发方法甚至是固件库方面都和STM32特别类似。
综上,把握STM32确实很有用,STM32最大的特征就是实在,把握这项技能很有助你找到一份工作,在单片机软硬件工程师这条路上能先上路,走出第一步。
03
STM32的局限性
不能说STM32不好,只能说有局限性。
STM32最大的局限性就是:它只是个单片机。
也就是说,你学习STM32,虽然学的都是单片机相关的技术。
比如GUI方面,你学STM32可能会学emWin,或则touchgfx,或则littlevgl等,而且你几乎肯定不会去学QT和android这些嵌入式linux应用层开发,由于STM32上通常不跑这种。(现今QT也有QTforMCU,也在STM3232HH7上做了合作,并且应用面有限,大部份人大部份项目不会使用)。
所以你学到的GUI技术全都是MCU领域使用的,而那些和主流的GUI的后端与业务逻辑分离的设计模式(典型的如谷歌的WPF,Android,或web后端设计等)是有不同的,因而你学到的东西也是有局限的。
再比如网路应用方面,STM32大多数应用都不带网路,即使带网路常常也是用通讯模组,甚少会须要你基于socket层直接编程,而这才是网路编程的关键技能。
所以好多做STM32多年的工程师,实际上对网路很陌生,甚至是一窍不通。
04
客观看待STM32
客观去看,STM32开发确实是电子相关专业朋友可以去学习的一项技能。
或则说,假如你准备学单片机,这么STM32绝对是首选。
其实了,首选不是说只学STM32,虽然我个人更推荐的单片机学习路径是先用51入门,再进阶到STM32,这样更符合学习规律,学习效率会更高。
所以说学STM32是没错的。
并且不是说只学STM32,这个必须认清楚。
苹果挺好吃,吃苹果对身体好,莫非你只吃苹果吗?
所以我觉得正确的对待STM32的心态是:
05
嵌入式Linux是STM32最好的延展
假如你STM32早已学得不错了,建议延展学习linux。
好多人认为linux使用没有STM32广泛,使用linux的设备远没有使用STM32的设备多,急聘岗位中linux相关也没有STM32相关的多,所以不应当去学linux而应当去学STM32。
这个观点是错的。
由于这个观点把STM32和linux用来对比了,但是这2个东西根本没有可比性。
你对比这2个就好象对比单车和小车辆,你说单车的优势是实惠,好维修,不塞车,不用交停路费,不耗油等等,你可以说出来单车相对小车辆的好多优势,但是该买小车辆的你给他个单车行吗?
小车辆是单车的延展,linux是STM32的延展,是类似的道理。
前者相对后者是升级的关键,而不是平行的关系。
06
为何说Linux是STM32的延展
我们说linux是STM32的延展,虽然是从技术角度出发的。
也就是说从技术的延续性,技术难度,技术拓展方向角度讲,STM32把握后再去拓展linux是十分合适的。
比如C语言,STM32用到的C语言特点和难度都要高于linux。
所以当你通过熟练把握STM32的过程早已一定程度把握了C语言,再去学嵌入式linux,读linux源码时,都会发觉自己的C语言造诣得到了升华。
而你读惯了linux内核源码后,再回过头来看STM32的标准库,HAL库时,都会觉得简单了好多。
从软件层次来讲也是这样。
比STM32更简单的单片机,例如51单片机,基本不使用库函数,都是程序员自己从零开始编程的。
51单片机的厂商通常也不会给你提供单片机的固件库,主要是太简单没必要。
而STM32就须要固件库嵌入式linux应用层开发,不管是初期的标准库还是现今的HAL库,都是芯片厂商提供的固件库,来辅助程序员来进行开发。
到了嵌入式linux阶段,分层就更复杂了。
和硬件相关的代码部分成了linux的驱动层,板载硬件管理由linux内核成立接管,顾客业务功能则由linux应用程序来完成。
假如须要网路,GUI等功能,也都有十分专业的内核层和应用层资源移植对接。
所以说,从技术角度讲linux文件系统,嵌入式linux是完全覆盖了STM32的。
07
嵌入式Linux的优势
虽然学习linux还有好多优势。
Linux内核可以说是整个开源软件社区的集大成者,在过去几六年间有大量世界级优质程序员向linuxkernel贡献代码和思想,也有大量的第三方开源项目基于linux的个别组件或linux的设计思想来建立。
比如国外现今很火的国产物联网操作系统rt-thread,你去读它的源码都会发觉,这完全就是linux的味道啊。你去看华为的物联网操作系统LiteOS,他的源码中各个组件之间分隔对接的osal设计,也是linuxkernel中大量使用的方法。
所以说为何要学linux?
由于它真的可以让你一劳永逸的解决往前职业生涯中遇见的大部份技术需求。
我们学习技术有个很大问题就是:你明天永远不晓得今天会做哪些工作,会须要哪些技能。
可能你下个月开个新项目新任务,老大都会给你一个你根本没听过名子的东西让你玩。你如何能够快速上手呢?
我的经验,最靠谱的就是学好linux。由于你会发觉你碰到的任何东西都有linux的影子。
只要你学好了linux,有这个功力,你学习任何新东西时就会很快。
我当初下决心学好linux就是由于分配到一个指纹锁研制的项目,用到的方案是一个美国科技公司开发的,他的开发环境是用cygwin,而我此前未曾接触过。折腾了半天搭建好环境我一看,这不就是linux的命令行嘛。还好我之前接触过简单的linux命令行,一下子觉得这个项目就不难了。
随后我就认识到linux的重要性了,下工夫好好学了linux,那么多年过来,太多事实案例证明,当时的决策十分英明。
08
不要限制自己
最后说一句,永远不要人为给自己设限,不要自己局限自己。
人要脚塌实地,不要好高骛远,这个没错。
学51,学STM32这都没错,很实际,很接地气。
假如你耗尽了竭力也能够将就学好这种,那就做单片机开发,也能找到工作。
而且假如你还有余力,还乐意继续下苦功学习,这么不要限制自己,继续向更高层次进发,永攀技术高峰。
要相信社会不会怠慢你,会用升职加薪来回馈你。
4.
6.