写点什么

开发者应该开始学习 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:477785
用户头像
臧秀涛 略懂技术的运营同学。

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

关注

评论

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

RocketMQ Schema——让消息成为流动的结构化数据

Apache RocketMQ

RocketMQ

如何优化大场景实时渲染?HMS Core 3D Engine这么做

HarmonyOS SDK

HMS Core

Laravel中HasOne和BelongsTo的区别

ModStart

重磅!TDengine 3.2.0 正式发布

TDengine

数据库 tdengine 时序数据库

我把整个研发中台拆分过程的一些心得总结

软件工程师-罗小东

Clickhouse表引擎探究-ReplacingMergeTree

京东科技开发者

Clickhouse 数据分片 数据验证 存储数据 MergeTree

数据存储,消息队列的高可用保障

C++后台开发

数据库 数据结构 消息队列 后端开发 linux开发

智能合约DAPP开发WEB3.0系统搭建技术

薇電13242772558

智能合约

直播|HashData信创概览

酷克数据HashData

信创

学习掌握哪些前端技术才能找到好工作?

小谷哥

小游戏流量变现都有哪些窍门?

FinFish

小游戏 微信小程序-游戏 小程序游戏 微信小游戏

我对管理角色带团队的一些经验分享

软件工程师-罗小东

我对中台的理解和企业数字中台建设的思考

软件工程师-罗小东

阿里云视觉智能开放平台——人脸活体检测算法重磅升级

夏夜许游

服务升级 人脸活体检测 人脸人体

汽车之家基于 Milvus 的向量检索平台实践

Zilliz

数据库 向量检索 Milvus

专利解析|数据中台—数据流配置弹框交互优化方法

元年技术洞察

数据中台 数字化转型 专利解析

HTTP报文内容

穿过生命散发芬芳

HTTP 12月月更

新华三推出人工智能模型训练平台,让智慧算力触手可及

脑极体

在新基建数字化的时代,寻找自我的突破和价值创造

软件工程师-罗小东

在北京选择哪家大数据培训机构

小谷哥

迁移速度与计算性能兼得!天翼云DirtyLimit技术大显身手

天翼云开发者社区

虚拟机 迁移 弹性计算

培训班出来前端程序员好找吗?

小谷哥

参加大数据培训可以找到工作吗

小谷哥

企业转型难?火山引擎数智平台提供数智升级新路径

字节跳动数据平台

大数据 数据中台 12 月 PK 榜

隐匿于喧嚣城市的世外桃源,「武汉浮生艺术馆」开放小程序预约通道,顺利举办多场艺术展览

天天预约

小程序 SaaS 预约工具 展览 艺术馆

【经验总结】HDI与普通PCB的4点主要区别

华秋PCB

工艺 PCB PCB设计

Amazon 4.7 星评,领域新经典,了解服务设计就读它

图灵社区

产品经理 设计模式 服务设计

盘点那些日赚万金的爆款小游戏

FinFish

小游戏 小程序游戏 微信小游戏 爆款小游戏

Java程序员培训机构怎么选

小谷哥

软件测试培训 | 在霍格沃兹测试开发学社学习是种怎样的体验?

霍格沃兹测试开发学社

大咖说·开源人说|数据库 PolarDB 开源的商业逻辑与价值思考

大咖说

数据库 阿里云 开源

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