在 2025 收官前,看清 Data + AI 的真实走向,点击查看 BUILD 大会精华版 了解详情
写点什么

开发者应该开始学习 C++ 吗?

  • 2012-12-20
  • 本文字数:1697 字

    阅读完需:约 6 分钟

随着 C++ 11 C++ CX 的引入,很多人重新燃起了对这门语言的兴趣。不少开发者,尤其是 Windows 开发者,都想知道是否应该放弃 C#和 Java,转而支持 C++。John Sonmez 认为这并不需要。

在“为什么 C++ 并没有‘王者归来’( Why C++ Is Not ‘Back’)”一文中,John Sonmez 认为只有如下三个原因才会使用 C++:

  • 需要榨干软件每一寸可能的性能,并且想用支持面向对象抽象的语言来实现。
  • 编写直接面对硬件的代码。(例如,编写底层驱动。)
  • 内存控制与定时极为重要,因而系统的行为必须是完全确定的,还必须能够手动管理内存。(想一下控制机器移动部件的嵌入式实时操作系统。)

Herb Sutter 高度称赞了这篇文章,认为文中的“观点有些深度,没有夸张”。关于 C++ 的应用场景,他又做了一些补充:

  • 服务,依赖于运行时会更为困难。
  • 测试,对比一下全部或者大部分采用静态链接的应用程序与在最终用户机器上往往是首次执行时才编译或即时编译(JIT)的应用程序,后者无法完整地测试。

John Sonmez 反对学习 C++,过于复杂是原因之一。即使 C++ 11 让开发容易了一些,但是程序员仍然不得不学习各种老式的 C++ 编码方法。“你会碰到 20 年前的 C++ 代码,看起来就像是完全不同的语言。”为了加强其观点,他向准备应聘 C++ 职位的开发者提出了 36 个问题。下面列出几条:

1. 在 C++ 中,基本数据类型有多少种初始化方式?你能都说出来吗?
12. 什么是复制构造函数,何时会用到?尤其是与赋值操作符相比,你能区分吗?
16. 在 C++ 中,何时适合通过引用来返回值,何时不适合?
33. 为什么绝对不应该在析构函数中抛出异常?

反对 C++ 的另一个理由是“编程语言真正需要的是简化并提高抽象层次,而不是反其道而行之”。他继续道,

编写底层代码的需求总是存在的,但我们今天编写的大部分都是较高层次的代码。

很多年前,当我终于无法再坚持认为我用 C++ 开发应用的速度比 C#快时,我跳下了 C++ 这条船。

我坚持良久,试图让自己相信我在 C++ 上的所有投入并没有白费,但是事实证明, C#带来的简化是如此之大,以至于与此相比,C++ 所提供的额外的力量并不值得这些额外的付出。

在文章结尾,John Sonmez 说到,学习 C++ 对于理解计算机的一般工作原理仍然是有用的,“但是我认为 C++ 不会东山再起,这是好事”。

关于这一点,Alo 补充到:

我是从 C++ 开始的,而且我职业生涯的前四年都花在了 C++ 上。这种经验对我非常有价值,正如您的文章中所指出的那样,因为一旦把 C++ 学到了足够的水平,就可以很快地捡起其他任何语言;此外,还能从一个更低的层次上更深刻地理解软件工作原理——如果从其他层次更高的语言开始学习编程,获得这种知识的难度就大多了。正因如此,我一直不赞成让程序员从 Java 开始学起。

Richard Dunks 反驳到:

我认为,在第一学期的程序设计导论课程和数据结构的教学中,C++ 是没什么帮助的,因为光实现就要耗费很多时间,反而让同学们忽略了他们要复现的结构。我很高兴自己能够精通 C++,但我认为这并不值得,而且 C++ 绝对不是一门万能的教学语言。

Stephen Cleary 有一条评论谈到了可重用性:

我原来是 C++ 开发者,几年之前,市场的压力让我成了一名 C#开发者。C#的确更有生产率,但是完全不可能实现 C++ 模板那种级别的代码复用。

经典的例子就是容器、迭代器和算法这三驾马车。在 C++ 中,能够创建一个用于任何容器的算法,而且可以在编译时对算法加以调整以便必要的情况下利用随机访问能力。你可以用 C#试试。这还是尚未谈到“新 C++”的情况;1998 年的 C++ 对代码复用的支持就比现在的 C#好了。

关于性能,Herb Sutter 给出了如下建议:

在任何语言中,如果非常关注性能,都会大量使用数组(未必“总是”使用,只是“大量”用到)。不过这在有些语言中很容易,可以很好地控制一般内存布局,特别是控制数组;而在其他语言或环境中就困难一些(有可能让你使用,但更为困难),如果这些语言或运行时特别偏爱通过指针构造的数据结构,你就不得不“放弃”或者“尽量避开”。

除了在 Herb Sutter 和 John Sonmez 的相关博客上的大量高质量评论,Reddit 的 Programming Coding 子群组也有很多可以学习的东西。

参考英文原文 Should Developers Start Learning C++?

2012-12-20 04:478361
用户头像
臧秀涛 略懂技术的运营同学。

发布了 300 篇内容, 共 152.1 次阅读, 收获喜欢 35 次。

关注

评论

发布
暂无评论
发现更多内容

Docker下Prometheus和Grafana三部曲之一:极速体验

程序员欣宸

Grafana Prometheus 8月月更

万物皆可集成系列:低代码释放用友U8+深度价值(2)—数据拓展应用

葡萄城技术团队

低代码 用友

面试半月,阿里三面挂在微服务,我整个人直接麻了

Java永远的神

程序员 微服务 程序人生 Java 面试 架构师

企业统一门户 | WorkPlus深度集成,优化企业管理模式

BeeWorks

MobTech ShareSDK Android端微信分享小程序

MobTech袤博科技

微信小程序 android sdk

自从外包干了七年,废了.....!

退休的汤姆

Java 面经 社招 Java工程师 秋招

企业即时通讯怎样为企业实现移动办公效率的极致化?

BeeWorks

105份墨天轮“国产化迁移”干货文档汇总(含TiDB、openGauss、上云等)

墨天轮

数据库 阿里云 TiDB 国产数据库 达梦

画出“伦勃朗光线”:vivo的夜色4K探索之旅

脑极体

蛇行矩阵 蛇形填数 回形取数 蛇行系类(C语言详解+图解)

Five

c 算法题 8月月更

兆骑科创双创服务平台,留学生海外创新创业大赛,人才引进

兆骑科创凤阁

MQTT协议详解及v5.0实践——实践类

阿里云AIoT

物联网 调度 网路协议 网络性能优化 网路架构

1 分钟在 Serverless 上部署现代化 Deno Web 应用

阿里巴巴中间件

阿里云 Serverless 云原生

“似水无形” 的小程序化技术

Speedoooo

小程序 小程序管理平台 轻应用 快应用 小程序平台

旺链科技荣登“长三角产业区块链企业30强”!

旺链科技

区块链 产业区块链 创新应用

基础+进阶+源码+实战,阿里SpringCloud Alibaba全解手册限时开源~

Java全栈架构师

程序员 面试 微服务 架构师 SpringCloud

SpringBoot 整合 数据库连接池(Druid、HicariCP、C3P0等等)

SpringBoot 2 Druid 8月月更

KusionStack 在蚂蚁集团的探索实践 (上)

SOFAStack

开源 技术分享 蚂蚁集团 Kusion kusionstack

打补丁是什么意思?如何快速对云主机批量打补丁?用什么软件?

行云管家

运维 云主机 IT运维 打补丁

浅谈 malloc 函数在单片机上的应用

矜辰所致

malloc 内存管理 8月月更

将 SAP Spartacus 作为 feature module 进行 Lazy Load 延迟加载时遇到的注入错误分析

汪子熙

typescript 前端开发 angular Spartacus 8月月更

2022年十大知名堡垒机品牌你真的知道吗?

行云管家

网络安全 数据安全 堡垒机 堡垒机品牌

全网独一份!清华大牛联合众多一线大厂架构师整合的Java面试突击手册开源

程序员小毕

程序员 程序人生 JVM 高并发 java面试

2022年中国小微信贷市场发展分析

易观分析

市场分析 小微信贷 易观

激动!开启轻量化虚拟直播时代!

IT资讯搬运工

大型LED显示屏怎样做好保养维护

Dylan

LED显示屏 led显示屏厂家

B站基于Iceberg+Alluxio助力湖仓一体项目落地实践

Alluxio

B站 iceberg Alluxio 湖仓一体 8月月更

本周四晚19:00知识赋能第七期第3课丨OpenHarmony WiFi扫描仪实现

OpenHarmony开发者

OpenHarmony

Gitlab 中 Github import 功能存在远程代码执行漏洞

墨菲安全

业务出海必答题,融云全球通信网络技术挑战破解实践

融云 RongCloud

开发者应该开始学习C++吗?_C++_Jonathan Allen_InfoQ精选文章