C++两大派系之争

C语言与CPP编程 2024-12-04 09:01

击上方“C语言与CPP编程”,选择“关注/置顶/星标公众号

干货福利,第一时间送达!

最近有小伙伴说没有收到当天的文章推送,这是因为微信改了推送机制,有一部分小伙伴刷不到当天的文章,一些比较实用的知识和信息,错过了就是错过了,建议大家加个星标⭐️,就能第一时间收到推送。

关于 C++ 的未来,近段时间似乎引发不少的争论。无论是在 Reddit、HN 上,还是在 C++ 标准委员会的会议上,四处可见这些讨论。

1、C++ 的现状

当前,我们所使用的 C++ 似乎正处于以下局面:

 1. C++ 的演进工作组(EWG)刚刚就采纳 P3466 R0 达成共识——即,(重新)确认未来 C++ 演进的设计原则:

  • 不允许 ABI(应用二进制接口)中断,保持与 C 以及早期 C++ 版本的链接兼容性。

  • 不引入“病毒式注解”(例如,不支持生命周期注解)。

  • 坚持一组互相矛盾的目标,例如同时要求不破坏 ABI 和零开销原则。

这无论这是好是坏,都表明 C++ 的发展方向在进一步巩固当前的轨迹。

2. 与此同时,一方面,美国政府希望人们停止使用 C++:

  • 美国网络安全和基础设施安全局(CISA)

  • 美国国家安全局(NSA)

  • 甚至白宫

截至目前,美国政府的各个部门已经发布了文件、报告和建议,警告行业不要使用内存不安全的语言。

3. 各种大型科技公司正在采用 Rust:

  • 微软显然正在用 Rust 重写核心库:去年 10 月,微软在 GitHub 中发布了一系列开发工具包,让开发者可以使用 Rust 语言来编写 Windows 驱动程序。

  • 谷歌似乎也致力于 Rust:其先是宣布支持使用 Rust 开发 Chromium,同时也开发一个双向 C++/Rust 互操作工具。

  • 2019 年,AWS 表示开始在其基础架构中越来越多地使用 Rust 后,决定赞助 Rust,即 Rust 团队可以优惠租用 AWS 基础设施以进行语言开发。

  • ......

说到大型科技公司,近期还有几件事值得注意:

  • 不久前,ISO C++ 委员会主席 Herb Sutter 在其个人博客宣布,他已经离开了工作 22 年的微软,正式成为金融公司 Citadel Securities 的一名技术研究员。而 MSVC(Microsoft Visual C+)似乎在实现 C++23 功能上进展缓慢,还在向社区征求优先级意见。

  • 臭名昭著的布拉格 ABI 投票事件发生了(简而言之:“C++ 23 不会破坏 ABI,将来是否会破坏也尚不明朗。”),据说 Google 大幅减少了参与 C 开发过程的工作,转而开始开发自己的 C++ 后续语言——Carbon。他们甚至写了一个文档,总结他们在尝试改进 C++ 时遇到的种种困难(https://github.com/carbon-language/carbon-lang/blob/trunk/docs/project/difficulties_improving_cpp.md)

4. 社区中的问题:

  • 之前有很多人分享过自己尽最大努力参与 C++ 标准委员会的过程,但最终却被消耗殆尽。即使有些功能在 C 中实现了也没有什么用。

  • 事到如今,模块功能尚未实现。我们有模块了吗?答案是否定的。

  • 相信不少人还记得在 2023 年 CppCon 2023 的演讲中,C++ 之父 Bjarne Stroustrup 首次提出了安全配置文件(Safety Profiles)的概念,目的是为 C++ 提供更强的类型和资源安全性,同时尽量避免破坏现有的兼容性。Safety Profiles 的核心是通过一组规则和工具引导开发者编写更安全的代码,同时允许不同的项目根据需求选择适合的安全级别。然而,“安全配置文件”(Safety Profiles)仍处于一种奇怪的状态,没有任何现有实现,它试图在尽量减少对现有代码更改的情况下,为现有的 C++ 代码增加某种程度的安全性。C++ 联盟开发人员 Sean Gaxter(Circle 编译器的创造者)本人公开反对配置文件,称 C++ 为“定义不足”的语言。

我不知道你怎么看,但如果我作为一个外行人来看待这一切,C++ 似乎基本上已经分崩离析了,而且似乎很多人已经对 C++ 委员会能够处理这些问题的能力失去了信心。

2、C++ 的两大派系

人们似乎正在寻找其他解决方案。

比如说 Google。自从 ABI 投票以来,Google 显然对“这一标准化流程”失去了信心。这种失望并非针对 C++ 语言本身——Google 自己拥有庞大的 C++ 代码库,这门语言对他们来说一直表现出色。然而,他们对 C++ 在多方压力(如潜在的政府监管、其他语言的竞争、大厂对更高性能和安全保障的需求等)下继续演进的能力失去了信心。

那么问题出现在哪里?为什么 C++ 不能做出改变呢?

答案其实很简单。我们可以参考 ISO C++ 委员会主席 Herb Sutter 在其关于配置文件的论文中所说的话:

“我们必须尽量减少对现有代码的修改需求。根据几十年的经验,对于拥有大型代码库的大多数客户来说,即便是为了安全原因,也不会因为严格性规则而修改哪怕 1% 的代码,除非有法规要求强制执行。”

——Herb Sutter

这很合理,不是吗?没人对此感到惊讶。

现在,对比一下 Google 工程师 Chandler Carruth 在 WG21 成员页面上的简介:

“我主导了基于 Clang 的 C++ 工具和自动化重构系统的设计,这些工具现在已成为 Clang 项目的一部分……

在 Google 内部,我带领团队将这些基于 Clang 的自动化重构工具扩展到整个代码库,超过 1 亿行 C++ 代码。我们可以在 20 分钟内对整个代码库进行分析并应用重构。”

看到了吗?这里 Chandler Carruth 提到了一个关键词是“自动化工具”。但不只是自动化迁移工具,这只是最显眼的例子。

两种 C++ 用户阵营的对立

实际上,我们看到的是两种完全不同的 C++ 用户阵营之间的冲突:

  • 相对现代、有能力的技术公司,它们明白自己的代码是一种资产。(这并不严格限于大科技公司。任何新兴的 C++ 初创公司也属于这一类。)

  • 其他所有人。那些仍在争论如何缩进代码的老牌公司,以及年轻工程师试图说服管理层允许他设置代码检查工具的情况。

这两种用户之间的关键区别在于:前者能够相对顺利地应对迁移,因为他们能从版本化源码构建整个 C++ 栈,而后者则仍在使用 1998 年的老旧库。

这种能力——从版本化源码构建整个依赖栈(最好还带有自动化测试)——是两大阵营之间最重要的分水岭。

当然,在实践中,这是一个渐进的过程。我可以想象,要把大公司的代码库从可怕的泥球变成半可管理、可构建、经过代码检查、适当版本化、稍微不那么可怕的泥球,必须流下多少汗水、泪水、账单和心血。

事后看来,很容易认为这一切都是不可避免的:像 Google 这样的公司(使用相对现代的 C++,拥有自动化工具和测试,以及现代基础设施)的需求与强烈向后兼容的愿望之间存在明显的脱节。

大胆地说,单一、无方言且统一的 C++ 的概念似乎已经死多年了。至少,我们有两种主流风格的 C++:

  • 稍微现代化一点的 C++。一切都可以通过某种专用、干净且统一的构建流程从版本化的源码构建,至少比原始 CMake 稍微复杂一些,如果稍微眯着眼睛看,它就能正常工作。包含一些静态分析器、格式化程序、代码检查器。任何一种保持代码库清洁和现代化是有价值的共识。可能至少是 C++17,带有`unique_ptr`、`constexpr`、`optional`等特性,但这不是重点。重要的是工具。

  • 传统的 C++。即任何不符合上述条件的 C++。比如那些存放在中型银行古老服务器上的 C++。任何依赖于某个完全古老且已编译代码块的 C++,其源码已经丢失,原作者也无法联系。任何部署在宠物类型服务器上的 C++,以至于在其他地方启动它需要工程师花整整一个月的时间来弄清楚所有隐含的依赖项、配置和环境变量。这些主要被归类为成本中心的代码库。任何从源码构建使用的二进制文件都需要按下不止几个按钮,或者根本无法构建的代码。

你会注意到,这两种文化的分歧不在于 C++ 语言本身,而是工具和是否能从版本化源码进行干净、有定义的构建。理想情况下,甚至能够在不需要记住以前开发者通常设置的那个标志或环境变量的情况下进行部署。

例如,Google 的代码库是否完全采用“现代” C++ 习惯用法并不是重点。关键是工具是否到位,以及是否能够从源码构建。

很多人会说工具不是 C++ 标准委员会的责任,这观点是对的。工具确实不是 C++ 标准委员会的责任,因为 C++ 标准委员会放弃了对它的责任(他们专注于语言规范,而非具体的实现)。这是设计使然,考虑到遗留负担很难去责怪他们。C++ 是一个统一不同实现的标准。

话虽如此,如果说 Go 语言有一件事做对了,那就是他们把工具放得很重要。相比之下,C++ 出生于一个比 linter 更古老的时代。C++ 没有统一的构建系统,也没有接近统一的包管理系统,语法复杂难以解析(这对工具来说很糟糕),且每次改动都在与 Hyrum 定律作斗争。

这两个派系(良好的工具,可以毫不费力地从源码构建 vs. 差劲的工具,无法从源码构建)之间存在着巨大的、不断扩大的裂痕,而且短期内看不到弥合的可能性。

C++ 委员会似乎坚决维护向后兼容性,无论代价如何。

顺便说一句,我并不一定反对这一点!向后兼容性对许多人来说非常重要,理由充分。然而,对另一些人而言,这并不重要。这不是谁“对”的问题,而是两种截然不同、无法调和的立场之间的冲突。

3、造成的后果

这就是为什么配置文件的设计是这样的:安全配置文件的目的并不是为了解决现代、技术娴熟的 C++ 公司的需求。它们是为了在不需要对旧代码进行任何更改的情况下带来改进。

同样地,对于模块也是如此。设计初衷是让你“只需”以模块形式导入头文件,而不会引发任何向后兼容性问题。

毫无疑问,大家都喜欢那些可以直接引入并在不改动旧代码的情况下带来改进的功能。但很明显,这些功能的设计初衷是为了迎合“传统 C++”的需求。任何需要从传统 C++ 迁移的功能对 C++ 标准委员会来说都是不可行的,因为正如 Herb Sutter 所说,你基本上不能指望人们自己去迁移。

(再次强调,考虑传统 C++ 的需求并不是坏事。这完全是一个合理的决策。)

这一点我始终牢记在心,每当我阅读 C++ 提案时都会注意:C++ 其实有两个主要受众群体。一是现代 C++ 用户,另一个是传统 C++ 用户。这两个阵营对许多问题的看法大相径庭,且许多提案都是针对其中一个特定群体的需求而撰写的。

显然,这导致了许多人无法互相理解,话说不到一块:尽管许多人以为安全配置文件和 safe C++ 是在解决同样的问题,实际上它们面向的是完全不同的受众,解决的是完全不同的问题。

C++ 委员会正试图阻止这种裂痕进一步扩大。这或许就是为什么 Sean Baxter 撰写的《 Safe C++》对他们来说毫无意义的原因。这种提案是一种激进且全面的变革,可能会开创一种完全不同的 C++ 编程方式。

当然,也有人提出另一个问题:是否某些 C++ 标准委员会成员只是过于固执,抓住各种理由来阻止他们个人在审美上不认可的演进。

这是否属实,我不便评判,但关于 C++ 标准委员会应用“双重标准”的说法并非首次听闻。比如“如果你想让这个提案被通过,我们要求你提供多个编译器的完整、可用的实现;但我们仍然愿意支持某些大项目(例如模块、配置文件),即便这些项目根本没有任何可用的概念验证实现。”

如果真是如此(我无法确证),我无法预测 C++ 还能沿着这条道路走多久,除非最终发生更为剧烈的分裂。

更不用提,打破 ABI 兼容性可能引发的巨大麻烦和一系列问题,那简直就是个无底洞。

4、C++ 未来将何去何从?

面对现代企业和遗留系统给 C++ 社区内部带来两极分化的趋势,不少网友看法不一。

来自 Reddit 的用户 ravixp 表示:

这让我感同身受,也许是因为我曾亲眼看到一个非常大的 C++ 代码库在不同层面和不同规模上,从“遗留”C++逐步过渡到“现代”C++的过程。这种转换涉及不同团队以各自的节奏和时间点推进,跨越了数十年的开发周期,至今仍在进行中。而任何新的代码现代化计划,都需要面对代码库中各部分的现代化水平不一致的问题。

(想象一下试图对这样的代码添加静态分析支持:它同时包含了 std::string、C 风格字符串,以及 20 年前 STL 性能较差时团队自行创建的字符串类型的奇怪中间状态!)

关键在于,现代化的成本非常高昂。这里提到的“现代”C++不仅仅是用不同的方式编写代码,它还包括一整套支持现代化标准的工具体系,这可能需要从零开始构建,还需要一个能够跟上 C++ 演进的工程团队。

需要牢记的是,这里的冲突并不是“喜欢遗留 C++”的人与“喜欢现代 C++”的人之间的矛盾,而是“能负担得起现代 C++”的人与“负担不起”的人之间的矛盾。C++ 的确需要改变,但真正的问题是:我们集体能够承受多少变化的成本,以及如何从中获得最大的价值。

Kronikarz 评价道:

从道德角度来看,我认为这反映了一种分歧:一部分人对 C++ 逐渐变成下一个 COBOL 不以为意,另一部分人则对这一想法感到排斥。

另一位网友 KittensInc 则认为:

遗留 C++ 正在迅速成为一种负担。美国政府已经意识到,通过做出不同的设计决策,可以完全避免某些类型的漏洞,并正在推动人们减少这些错误。我认为,负责管理责任的机构最终会加入这一趋势只是时间问题。

如果像缓冲区溢出这样的漏洞被认为是完全可以预防的,那么从逻辑上讲,如果某次黑客攻击、勒索软件事件或数据泄露的根本原因是缓冲区溢出,保险公司可能会拒绝赔付。这样一来,公司可能会要求软件供应商对其代码库进行第三方静态分析审计。

于是我们到达了这样一个节点:不进行现代化改造的成本变得过高。你要么升级你的代码库,要么你的公司走向灭亡。采用现代开发实践的企业只需运行一些简单的分析工具并完成一些文书工作,而那些没有任何像样工具并且背负着数十年技术债务的公司将陷入严重困境。

对此,你怎么看?

作者 | Mond      翻译 | 屠敏    出品 | CSDN(ID:CSDNnews)

分享一个福利

分享一个羊毛,最近极客时间出了一个《MySQL底层原理精讲》的专栏,目前还在内测阶段,主要是看市场反馈来定价,所以现在还是免费阶段,等上线了估计就可能收费了

除此外,附赠前人的MySQL学习笔记,有意扫码自取

MySQL学习笔记

一次吃透 MySQL 底层原理👉 架构篇、事务篇、索引与锁篇全覆盖,扫描下方二维码自取!


我组建了一些社群一起交流,群里有大牛也有小白,如果你有意可以一起进群交流。

欢迎你添加我的微信,我拉你进技术交流群。此外,我也会经常在微信上分享一些计算机学习经验以及工作体验,还有一些内推机会

加个微信,打开另一扇窗

感谢你的分享,点赞,在看三  


C语言与CPP编程 C语言/C++开发,C语言/C++基础知识,C语言/C++学习路线,C语言/C++进阶,数据结构;算法;python;计算机基础等
评论
  •     IPC-2581是基于ODB++标准、结合PCB行业特点而指定的PCB加工文件规范。    IPC-2581旨在替代CAM350格式,成为PCB加工行业的新的工业规范。    有一些免费软件,可以查看(不可修改)IPC-2581数据文件。这些软件典型用途是工艺校核。    1. Vu2581        出品:Downstream     
    电子知识打边炉 2025-01-22 11:12 28浏览
  • Ubuntu20.04默认情况下为root账号自动登录,本文介绍如何取消root账号自动登录,改为通过输入账号密码登录,使用触觉智能EVB3568鸿蒙开发板演示,搭载瑞芯微RK3568,四核A55处理器,主频2.0Ghz,1T算力NPU;支持OpenHarmony5.0及Linux、Android等操作系统,接口丰富,开发评估快人一步!添加新账号1、使用adduser命令来添加新用户,用户名以industio为例,系统会提示设置密码以及其他信息,您可以根据需要填写或跳过,命令如下:root@id
    Industio_触觉智能 2025-01-17 14:14 117浏览
  • 现在为止,我们已经完成了Purple Pi OH主板的串口调试和部分配件的连接,接下来,让我们趁热打铁,完成剩余配件的连接!注:配件连接前请断开主板所有供电,避免敏感电路损坏!1.1 耳机接口主板有一路OTMP 标准四节耳机座J6,具备进行音频输出及录音功能,接入耳机后声音将优先从耳机输出,如下图所示:1.21.2 相机接口MIPI CSI 接口如上图所示,支持OV5648 和OV8858 摄像头模组。接入摄像头模组后,使用系统相机软件打开相机拍照和录像,如下图所示:1.3 以太网接口主板有一路
    Industio_触觉智能 2025-01-20 11:04 141浏览
  • 本文介绍瑞芯微开发板/主板Android配置APK默认开启性能模式方法,开启性能模式后,APK的CPU使用优先级会有所提高。触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。源码修改修改源码根目录下文件device/rockchip/rk3562/package_performance.xml并添加以下内容,注意"+"号为添加内容,"com.tencent.mm"为AP
    Industio_触觉智能 2025-01-17 14:09 159浏览
  •  光伏及击穿,都可视之为 复合的逆过程,但是,复合、光伏与击穿,不单是进程的方向相反,偏置状态也不一样,复合的工况,是正偏,光伏是零偏,击穿与漂移则是反偏,光伏的能源是外来的,而击穿消耗的是结区自身和电源的能量,漂移的载流子是 客席载流子,须借外延层才能引入,客席载流子 不受反偏PN结的空乏区阻碍,能漂不能漂,只取决于反偏PN结是否处于外延层的「射程」范围,而穿通的成因,则是因耗尽层的过度扩张,致使跟 端子、外延层或其他空乏区 碰触,当耗尽层融通,耐压 (反向阻断能力) 即告彻底丧失,
    MrCU204 2025-01-17 11:30 176浏览
  • 2024年是很平淡的一年,能保住饭碗就是万幸了,公司业绩不好,跳槽又不敢跳,还有一个原因就是老板对我们这些员工还是很好的,碍于人情也不能在公司困难时去雪上加霜。在工作其间遇到的大问题没有,小问题还是有不少,这里就举一两个来说一下。第一个就是,先看下下面的这个封装,你能猜出它的引脚间距是多少吗?这种排线座比较常规的是0.6mm间距(即排线是0.3mm间距)的,而这个规格也是我们用得最多的,所以我们按惯性思维来看的话,就会认为这个座子就是0.6mm间距的,这样往往就不会去细看规格书了,所以这次的运气
    wuliangu 2025-01-21 00:15 151浏览
  • 嘿,咱来聊聊RISC-V MCU技术哈。 这RISC-V MCU技术呢,简单来说就是基于一个叫RISC-V的指令集架构做出的微控制器技术。RISC-V这个啊,2010年的时候,是加州大学伯克利分校的研究团队弄出来的,目的就是想搞个新的、开放的指令集架构,能跟上现代计算的需要。到了2015年,专门成立了个RISC-V基金会,让这个架构更标准,也更好地推广开了。这几年啊,这个RISC-V的生态系统发展得可快了,好多公司和机构都加入了RISC-V International,还推出了不少RISC-V
    丙丁先生 2025-01-21 12:10 99浏览
  •  万万没想到!科幻电影中的人形机器人,正在一步步走进我们人类的日常生活中来了。1月17日,乐聚将第100台全尺寸人形机器人交付北汽越野车,再次吹响了人形机器人疯狂进厂打工的号角。无独有尔,银河通用机器人作为一家成立不到两年时间的创业公司,在短短一年多时间内推出革命性的第一代产品Galbot G1,这是一款轮式、双臂、身体可折叠的人形机器人,得到了美团战投、经纬创投、IDG资本等众多投资方的认可。作为一家成立仅仅只有两年多时间的企业,智元机器人也把机器人从梦想带进了现实。2024年8月1
    刘旷 2025-01-21 11:15 237浏览
  • 数字隔离芯片是一种实现电气隔离功能的集成电路,在工业自动化、汽车电子、光伏储能与电力通信等领域的电气系统中发挥着至关重要的作用。其不仅可令高、低压系统之间相互独立,提高低压系统的抗干扰能力,同时还可确保高、低压系统之间的安全交互,使系统稳定工作,并避免操作者遭受来自高压系统的电击伤害。典型数字隔离芯片的简化原理图值得一提的是,数字隔离芯片历经多年发展,其应用范围已十分广泛,凡涉及到在高、低压系统之间进行信号传输的场景中基本都需要应用到此种芯片。那么,电气工程师在进行电路设计时到底该如何评估选择一
    华普微HOPERF 2025-01-20 16:50 69浏览
  • 高速先生成员--黄刚这不马上就要过年了嘛,高速先生就不打算给大家上难度了,整一篇简单但很实用的文章给大伙瞧瞧好了。相信这个标题一出来,尤其对于PCB设计工程师来说,心就立马凉了半截。他们辛辛苦苦进行PCB的过孔设计,高速先生居然说设计多大的过孔他们不关心!另外估计这时候就跳出很多“挑刺”的粉丝了哈,因为翻看很多以往的文章,高速先生都表达了过孔孔径对高速性能的影响是很大的哦!咋滴,今天居然说孔径不关心了?别,别急哈,听高速先生在这篇文章中娓娓道来。首先还是要对各位设计工程师的设计表示肯定,毕竟像我
    一博科技 2025-01-21 16:17 94浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦