凡是机器性能过剩,人力成本高的场合,差不多都可以淘汰了。
反过来不但要用C,还要用汇编呢。
举个极端点的例子,attiny13,在arduino上也算常见了,总共1k的rom,64字节的ram。用c和汇编以外的语言试试?
配置更低的还有pic10f20x系列,最少只有256字节rom和16字节ram。它们的用量(包括各种山寨,比如em78系列,国产也有n家)绝对大到超出你的想象。
C/C++会不会被时代淘汰?这个问题跳过了一步,关键是这个问题:
C/C++有哪些其它语言难以代替的特殊之处?
一般我们常说:C/C++具有较高的执行效率。其实这句话不是特别准确,有时候它们并不一定效率高。换句更恰当的话说:
C/C++,特别是C语言,控制粒度很细,与机器语言有着相当稳固的对应关系。
以C语言的if...else为例,它的汇编代码如下图所示。
参考链接:https://blog.csdn.net/weixin_34239592/article/details/91892372
也就是说,高手可以通过C语言写出完全按照自己的想法运行的程序。从C代码可以直接对应到汇编语言,如果你对C语言有足够的了解,代码在运行时实际做了哪些事情,是相当明确的。
C/C++甚至能指导编译器哪些变量优先放在寄存器,哪些函数内联,哪些变量要避免多线程抢夺,均可以进行非常细致的控制。
与此相反,Java、Python等高级语言在执行时会跨越很多层次。高级语言源代码 ->中间语言 -> 虚拟机执行 -> 分解执行流程 -> 实际执行的一系列操作。这其中的每一步都不是那么简单,最普通的一句代码:
c = a+b
会因为a或b的元方法,产生无数的执行可能性。除非仔细分析每一个细节,否则编程者对于最终代码的执行逻辑是缺乏控制力的,也不可能进行汇编级别的优化。
总结来说,C/C++,特别是C语言,有着极为精细的控制粒度,而更高级的现代语言一般无法进行如此细致的控制。
需要程序员压榨每一分硬件性能的地方并不多,特别是现在的服务器核心数很多,只要能充分利用多核心,每个核心没有完全挖掘也是可以接受的。
一般来说,需要压榨硬件潜力的领域有:
1、操作系统。因为每个人每天都要用操作系统,操作系统(特别是内核和驱动层),对优化要求非常高。例如如果对Windows磁盘读取优化1%,几乎全世界电脑用户都会受益1%。
2、游戏引擎。游戏是硬件进步的原动力,大型游戏开发商总是在尽力压榨每一分硬件性能,在60帧以上无止境优化视觉效果、动态效果。C++一直以来都是编写游戏引擎的首选语言,而且几乎是唯一语言。(游戏开发可以用各种技术,但引擎本身一般是用C++编写)
3、嵌入式程序。由于单片机的硬件性能较弱,存储空间极小,必须编写专用的程序代码,使用高级语言可能导致延迟过大,或容量超出限制。未来“万物互联”的潮流,可能会引发超微型嵌入式系统的再度复兴。
4、加密与安全方向。大部分加密/解密模块,与操作系统一样,每个人每天都会频繁使用,所以用C/C++来深入优化是必须的;另外,很多软件硬件漏洞,例如常见的内存溢出漏洞,也需要编写很精巧的C/C++代码才好利用漏洞,才能编写木马或者直接入侵系统。
总之,C/C++的不可替代性是由它本身的特点决定的。而且目前来看,这种不可替代性在未来几年、几十年也依然不会有变化。
因为现在这个时代,天天唱衰C/C++的人,熟练地使用现代语言,高效地调用着那些食古不化的C/C++开发者所提供的基础设施和功能,做出各种漂亮的软件,然后鄙夷地看了一眼下面的那群老顽固:何不食肉糜?
————————
以上半玩笑半认真吧。下面说点儿有营养的。
一些同学可能出于自己学习的感受,另外一些可能是根据别人(包括一些业界大佬)所说的话,认定C++是一个混乱不堪的语言。
的确,这话在某个角度上没错。Rust等在这个意义上进步很大也没错。
但是我想说一个事情。日本前首相鸠山有一句名言,那就是当记者问他为啥上台之后很多竞选时作出的承诺都没有兑现的时候,他回答说因为那时作为在野党站着说话不腰疼。(其实原文更加接近“不当家不知柴米油盐贵”)
这是个笑话,也是实话。
C++变成现在这个样子,固然有语言本身设计的问题,但是更多的是因为其肩负了太多,跨度太大,要满足各种各样的需求。
其实,成熟的开发商,没有人会去试图在一个应用当中去使用C++的所有特性。你所看到的混乱,只是因为你把它作为一个整体去看,以为任何特性在任何时候都是必要的。(更不要说那些其实只是听别人这么说的)
Rust等之所以现在能够那么美丽,也是因为其是个在野党,给你看了它最擅长的一面。等到它真的挑了大梁,会发展成啥样,真不好说。
复杂的是这个世界本身。混乱的也是这个世界本身,以及人心无穷无尽的欲望。
其实问题当中的“越来越多”,恰恰是反映了这个世界的复杂。要么用一个自身复杂度足够高的语言,如C++;要么就要细分应用,各自使用专用语言才能起到简化作用。
没有任何偏向的意思。期待能有更好的解决方案。作为C++坑里爬出来的,表示学习Rust易如反掌。
刚刚看了一 Uncle Bob Martin 的视频 The Future of Programming,谈谈编程语言。
目前的状况是,语言越来越多(各种框架、库也是),但我们似乎并不满足我们自己的语言。而事实上,1960年代三大范式(函数、对象、结构化)出现以后,语言本身并没有本质的变化,把1968年的Cobol程序员抓到今天,等他(她)从惊恐中缓过来以后,给个intelligent J他们还是能开始编程。
变化的是程序员。1970年以后,程序员(cs专业毕业生)每5年增长一倍,也就是说,市场上永远有一半的程序员经验不足5年。好的教师数量根本跟不上培训他们。
为了“管住”这些人,各种语言特性开始出现,更不用提“项目经理”的引入产生的干扰。但无论语言特性如何绚丽,最终还是 assign、if、while,这些在1960年代的语言都可以处理。
每当20几岁的程序员工作20年以后,他们也将终于能够理解1960年代前辈的智慧,然而他们终究是少数。所以 c、lisp还在,但新语言仍然不断出现。程序员构成成分和比例的原因。
而我个人认为精力应该放在用语言实现的软件、应用、功能上,而非隔几年就重置一次用新语言的新特性来重写一样的功能。