`
阿尔萨斯
  • 浏览: 4170311 次
社区版块
存档分类
最新评论

《Exceptional C++ Style》译序[已出版]

 
阅读更多
<iframe align="center" marginwidth="0" marginheight="0" src="http://www.zealware.com/csdnblog.html" frameborder="0" width="728" scrolling="no" height="90"></iframe>

Exceptional C++ Style》译序

by 刘未鹏

逍遥派武功讲究轻灵飘逸,闲雅清隽,丁春秋和虚竹这一交上手,但见一个童颜白发,宛如神仙,一个僧袖飘飘,冷若御风。两人都是一沾即走,当真便似一对花间蝴蝶,蹁跹不定,于这“逍遥”二字发挥到了淋漓尽致。旁观群雄于这逍遥派的武功大都从未见过,一个个看得心旷神怡,均想:“这二人招招凶险,攻向敌人要害,偏生姿式却如此优雅美观,直如舞蹈。这般举重若轻、潇洒如意的掌法,我可从来没见过...

—— 金庸 《天龙八部》

金庸小说中描绘的逍遥派武功讲究的是飘逸灵动,然则绝非片面追求招式漂亮,招招看起来都优雅美观,但招招都攻往要害。

写代码也如此。

毫无疑问,代码的目的是实现既定的功能,所以实用论者可能会说代码只需实现既定功能即可,无需费时费事去搞那么多周折弄那么多形式。但问题是,如果代码写完了就永远不用管它就好了,如果的确如此的话,这番论断倒是言之有理的。然而事实是,代码的维护占用了软件开发中的大部分乃至绝大部分时间和人力。譬如说做外包业务的公司大部分时间都是在维护代码,或者说改代码,而不是原生开发,这便意味着买来的代码的形式“漂亮”与否直接关系到一个项目的开销。另外,一般的公司,就算是作坊公司,日积月累,也一定会有自己的代码库,自己的遗留代码,只要他们想节省开销,复用以前写成的代码是必由之路,因此这里代码的可读性,代码结构的可扩展性等等就变得异常重要了,有过一些经验的程序员都会说维护别人(甚至自己)的代码是最痛苦的事情可见代码的“形式”构成了软件质量的一个重要部分。无论如何,就像政治书上听得我们耳朵都起茧子的那句话所言:“内容决定形式,但形式对内容也有反作用”。

然而徒有其表的代码也只是个花架子,没有真材实料,再花哨的形式也无济于事。软件归根到底要的还是功能。这就好比练武,光有花拳绣腿而没有扎实的内功是万万成不了气候的。

那么,在软件开发领域,这两者到底矛不矛盾呢?答案是根本不矛盾。之所以我们平时无法鱼和熊掌兼得,一方面固然是由于deadline的缘故,另一方面也与编码时的方法学有一定关系。

本书讨论的正是后者。

正是由于C++是一门非常自由的语言,因此C++编码的“形式”才变得异常重要,以至于一些大公司都规定了各自的编码标准。本书正是着眼于C++编码风格的一本书,但这里所谓的编码风格并非指命名风格、注释风格之类的浅显的东西,而是指在某些特定的问题领域所采取的编码方式(或“形式”)。C++中往往有若干条道路都能通往同一个终点,问题是选择哪条道路才是最具有洞见性的,最能达到形式和内容的统一,这一点很关键。

为此,本书的40个条款围绕C++日常编码中的种种问题展开讨论,详细考察各解决方案之间的优劣,最终给出权衡之下最为妥帖的方案并将其提炼为一条条的编码方针。

武侠小说的读者大多数都希望看到招式漂亮而又非常厉害的武功,觉着很过瘾。殊不知维护代码的程序员何尝不希望看到写得漂亮而又有实在功能的代码呢?

相信你在Sutter的书中能够找到一些答案。

最后,感谢老朋友谢轩和罗翼,跟他们讨论问题是我的快乐,谢轩(《Symbian OS Explained》译者)提供了第34章(原样章)的译稿、罗翼则无偿帮我初译了第六部分,他们的热情给了我莫大的帮助,他们的技术和文笔也让我获益颇多

感谢父母一直以来的支持,令我不敢懈怠。

刘未鹏

0510

于南京




分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics