查看原文
其他

为什么我们需要C程序员

蒋步星 数据蒋堂 2023-02-25

再说一个招聘的话题。

大家可能知道,润乾的软件产品主体都是Java写的,几乎没有别的语言。但是,我们在招聘算法程序员时,从来都要求C语言背景,会不会Java反而无所谓,而如果没有C语言功底则免谈。事实上,现在润乾研发部几个做算法的程序员,都是来了公司之后才学习使用Java的。

为什么我们会这么关注C/C++?


润乾是做基础软件的,而编写底层代码的技术逻辑和界面有很大不同。底层代码会被千百次的调用,一个函数哪怕只慢了1个微秒,被重复调用100万次时也会导致秒级的延迟。相对来讲,界面程序就不在意这些,代码再慢也不可能慢过人的操作,这时候的重点就变成用户体验而不是性能了。

想写出高效的代码,就必须深入理解计算机的运行原理,知道CPU、内存是如何工作的。应用程序员一般只关注业务功能的正确性,而一个好的系统级程序则不仅要保证正确性,还会习惯性地脑补出每一句代码被编译器翻译成什么样子了,最后会导致CPU和内存的哪些动作,从而判断出代码的效率。举个例子,new是Java代码中很常见的动作,但系统程序员却会很慎重地使用它,因为它涉及动态内存分配,是个非常复杂的任务,效率很低;但应用程序员则很少关注或了解这一点。

这种能力,常常是被C语言编程训练出来的。至少,容易通过考察C语言经验知道程序员是否具有这种能力。而其它程序设计语言则难有这种效用。


C语言的与众不同,关键在于其指针能力,包括函数指针。理解指针,本质上是理解CPU的工作原理,了解数据和代码在内存是如何存放的,CPU又是如何访问数据和执行代码的。说到底,其实是对汇编语言的熟悉。但汇编语言过于繁琐,C语言则是一个很好的抽象,即保留了大部分汇编语言的能力,又提供了更为宏观易读的描述方式。有了清晰的指针概念之后,也很容易理解C++(以及Java)中继承重载的具体实现方法,对于多继承(Java中取消了)也不会感觉到糊涂,也知道如何用非面向对象的语言(比如就是C语言)实现面向对象的机制(不仅能实现,反而会更灵活)。

不过,并不是所有程序员都能体会到这一点,有些程序员仅仅是使用C语言的语法,而避开指针的运用。这样,C语言成为众多程序设计语言“之一”了。


还有一个问题,我们为什么不直接用C语言写软件呢?

这个主要是兼容性的问题。C语言发明得太早,早于许多操作系统,每个操作系统下的C语言总有些不一样,这样想写一个兼容性很好的程序几乎是不可能的事情。不过现在这个问题开始弱化了,服务器端的操作系统快被linux垄断了,所以迟早有一天,我们也会把程序用C语言重写一遍。这些本来就有C功底的程序员就能进一步发挥到作用。


数据蒋堂 第二年原创文章

报表工具的SQL植入风险

内置的数据无法实现高性能

怎样生成有关联的测试数据

遍历复用

- 一些数据压缩手段

用HBase做高性能键值查询?

BI系统中容易被忽视的数据源功能

这个产品能支持多大数据量?

最简单的大数据性能估算方法

大清单报表应当怎么做?

大清单报表的打印?

大数据技术的4个E

做基础软件很悲壮?

做基础软件要投入很多钱?

- 国产操作系统还能怎么做?

- 国产数据库通通都没戏!

- 人工智能中的“人工”

- 存储和计算技术的选择

- 区块链技术的一些疑问

- 数据蒋堂新一年




润乾软件创始人、首席科学家

中国大数据产业生态联盟 专家委员

1989年国际奥林匹克数学竞赛团体冠军成员,个人金牌

清华大学计算机硕士

发明了非线性报表模型,并著《非线性报表模型原理》

创建离散数据集模型,颠覆四十年关系代数理论体系!

2016、2017年中国软件和信息服务业 • 十大领军人物

2017年度中国数据大工匠

数据领域专业技术讲堂《数据蒋堂》创办者



您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存