数学建模社区-数学中国

标题: C++之父B. Stroustrup近期言论(1) [打印本页]

作者: 韩冰    时间: 2005-1-26 01:03
标题: C++之父B. Stroustrup近期言论(1)
<>[译者按]  Bjarne Stroustrup博士,1950年出生于丹麦,先后毕业于丹麦阿鲁斯大学和 </P>6 ~) r- T! X3 p; o& P* C* e
<>英国剑桥大学,AT&amp;T大规模程序设计研究部门负责人,AT&amp;T、贝尔实验室和ACM成员。 </P>/ c- \: O6 Z4 d) G
<>1979年,B. S开始开发一种语言,当时称为“C with Class”,后来演化为C++。1998年 </P>
( L  V' s2 A) I' m3 m6 ~$ ^<>,ANSI/ISO C++标准建立,同年,B. S推出了其经典著作The C++ Programming Language </P>: y8 m( ~. U/ F3 L" ?3 Q$ x9 l
<>的第三版。C++的标准化标志着B. S博士倾20年心血的伟大构想终于实现。但是,计算技 </P>; m: [1 w: y% l6 K! x- V
<>术的发展一日千里,就在几年前人们还猜想C++最终将一统天下,然而随着Internet的爆 </P>' x( U7 M: o( ]1 g* u; s
<>炸性增长,类似Java、C#等新的、现代感十足的语言  咄逼人,各种Script语言更是如雨 </P>
. `  l8 ]8 U* n# b, {<>后春 穹追子肯帧 在这种情况下,人们不禁有些惶恐不安。C++是不是已经过时了呢?其 </P>
2 g' h, w1 G/ Z( E0 ]<>前景如何?标准C++有怎样的意义?应该如何学习?我们不妨看看B. S对这些问题的思考 </P>
7 ]; g9 C7 a3 w: z' q% A0 R$ ]<>。以下文字是译者从Stroustrup1998年之后发表的若干文章、谈话笔记中精选出来的,由 </P>
( Z7 l$ U" z8 g7 C. \<>于出处不一,内容多有重复,为保持完整,亦一并译出。 </P>
! x- y) R' F0 t<>  </P>) U6 \* H: e" B! L4 w/ p
<>以下内容选自B. S在自己主页上发表的FAQ </P>
1 M, j( q2 i1 p9 p! A& h<>1. 请谈谈C++书。 </P>
; m8 w% v/ q) [# T! w* y& q0 p<>没有,也不可能有一本书对于所有人来说都是最好的。不过对于那些真正的程序员来说, </P>
# G' p9 z* h* ^2 O0 w# g% k; C<>如果他喜欢从“经典风格”的书中间学习一些新的概念和技术,我推荐我的The C++ </P>/ |- _6 j( D3 b. |
<>rogramming Language, 1998年的第三版和特别版。那本书讲的是纯而又纯的C++,完全 </P>3 k3 q" p7 ~$ u. V: s  f; {
<>独立于平台和库(当然得讲到标准库)。该书面向那些有一定经验的程序员,帮助他们掌 </P>& S2 X) F' o# t7 x" m6 b
<>握C++,但不适合毫无经验的初学者入门,也不适合那些临时程序员品尝C++快餐。所以这 </P>
% [5 N, Q" t+ l' u  u<>本书的重点在于概念和技术,而且在完整性和精确性上下了不少功夫。如果你想知道为什 </P>. I7 R  F6 P- n- x
<>么C++会变成今天的模样,我的另一本书The Design and Evolution of C++ 能给你满意 </P>" _5 }. t5 y' ?3 D* V( o# ~- q
<>的答案。理解设计的原则和限制能帮助你写出更好的程序。<a href="http://www.accu.com" target="_blank" >www.accu.com</A>是最好的书评网 </P>
+ _% k  H% \" U( G/ ?" L! S<>站之一,很多有经验的程序员在此仗义执言,不妨去看看。 </P>
+ `: |8 k9 p4 W* p0 N( s<>  </P>& [* t& |# P" V& c+ h
<>2. 学习C++要花多长时间? </P>
% c  j) ?2 F& e. O3 k4 @/ f6 }- h<>这要看你说的“学习”是什么意思了。如果你是一个Pascal程序员,你应该能很快地使你 </P>$ q7 f' }( _3 U& [2 V
<>的C++水平达到与Pascal相近的程度;而如果你是一个C程序员,一天之内你就能学会使用 </P>
* U& n, j' x- K; [  }2 m" A/ `% P  w<>C++进行更出色的C风格编程。另一方面,如果你想完全掌握C++的主要机制,例如数据抽 </P>
' _* U# @' ]0 _, ~- k  I7 {! t<>象,面向对象编程,通用编程,面向对象设计等等,而此前又对这些东西不很熟悉的话, </P>
9 U7 q6 H: V2 [( ^0 ]' I% S5 F<P>花上个一两年是不足为奇的。那么是不是说这就是学习C++所需要的时间呢?也许再翻一 </P>
' X. l; Z, i/ r3 W( h; g<P>番,我想打算成为更出色的设计师和程序员最起码也要这么长的时间。如果学习一种新的 </P>
2 U# H8 D( |- m9 r6 c9 Q, `' f<P>语言不能使我们的工作和思想方式发生深刻的变革,那又何苦来哉?跟成为一个钢琴家或 </P>% E( c  `) U% e% g. i# V  T- P7 _/ p
<P>者熟练掌握一门外语相比,学习一种新的、不同的语言和编程风格还算是简单的。 </P>
# M; l, e& u& R1 K<P>  </P>
" b- O( D1 A# z, }7 f<P>3. 了解C是学习C++的先决条件吗? </P>2 ^, U% F9 J6 ^/ R  Z
<P>否!C++中与C相近的子集其实比C语言本身要好学,类型方面的错误会少一些,也不像C那 </P>
6 |$ j3 i4 ]& o) C6 _<P>样绕圈子,还有更好的支持库。所以应该从这个子集开始学习C++。 </P>
) u. Q. A2 ^2 _. E. ]% D6 a<P>  </P>9 V# p* ^% P. h9 Y
<P>4. 要想成为真正的OO程序员,我是不是得先学习Smalltalk? </P>
  Y0 D- o1 B4 j<P>否。如果你想学Smalltaok,尽管去学。这种语言很有趣,而且学习新东西总是一个好主 </P>
  H' t" e; E3 D4 j! N, f2 c<P>意。但是Smalltalk不是C++,而且把Smalltalk的编程风格用在C++里不会有什么好结果。 </P>
8 X, j9 L3 n- d- I<P>如果你想成为一个出色的C++程序员,而且也没有几个月的时间百无聊赖,请你集中力量 </P>
* U5 C& c* N" _- j! l' Z& V<P>学好C++以及其背后的思想。 </P>) r* u5 S5 n( l- }' P. g8 K9 @
<P>  </P>
9 a2 f' M6 D8 u2 t<P>5. 我如何开始学习C++? </P>$ E: q7 J7 M& P: f: F! z
<P>这取决于你的基础和学习动机。如果你是个初学者,我想你最好找个有经验的程序员来帮 </P>
3 ^3 n7 ^- y* C; j$ D<P>助你,要不然你在学习和实践中不可避免的犯下的种种错误会大大地打击你的积极性。另 </P>
6 v) w& Y, E7 P( R3 g<P>外,即使你的编译器配备了充足的文档资料,一本C++书籍也永远是必不可少的,毕竟文 </P>
7 j/ _" U0 U7 w+ I$ `. J" `6 t<P>档资料不是学习编程思想的好教材。 </P>; O- e9 Q/ d, l* Z
<P>选择书籍时,务必注意该书是不是从一开始就讲授标准C++,并且矢志不渝地使用标准库 </P>4 h" G1 Y! j# ?$ i, `% t( J
<P>机制。例如,从输入中读取一个字符串应该是这样的: </P>
5 I; m" y  _# c<P>        string s;       // Standard C++ style </P>
7 M/ z1 b0 \  O0 D; x<P>        cin &gt;&gt; s; </P>
+ Y" K# S1 a( @% b) J<P>而不是这样的: </P>  ?9 ]- Z9 {# a& x9 z8 _. }0 U
<P>        char s[MAX];     /* Standard C style */ </P>
8 m& }6 n, J1 Q& T7 w4 q) I. H<P>        scanf("%s",s); </P>
8 [/ O$ F/ F' S% o<P>去看看那些扎实的C++程序员们推荐的书吧。记住,没有哪本书对所有人来说都是最好的 </P>
" b" y; n2 m1 w6 t  R2 x4 Z7 K" t<P>。 </P>: c1 d2 g- ^- G7 B0 R- u
<P>另外,要写地道的C++程序,而避免用C++的语法写传统风格的程序,新瓶装旧酒没多大意 </P>! s( `+ H% L4 K" X5 `9 T
<P>义。 </P>
: a3 i& a* O$ y. A0 ^! Q<P>(遗憾的是,目前在市面上的中文C++教材中,符合B. S的这个标准的可以说一本都没有 </P>
; @( F) ^( |' A( q<P>,大家只好到网上找一些英文的资料来学习了。——译者) </P>
: K2 @# p. l7 Y: Q<P>  </P>0 L9 t8 c, x5 A/ L4 M7 w
<P>6. 怎样改进我的C++程序? </P>+ k/ ]% P% A3 s) B5 x
<P>不好说。这取决于你是怎么使用该语言的。大多数人低估了抽象类和模板的价值,反过来 </P>
( }) Y, d8 e+ T- n<P>却肆无忌惮地使用造型机制(cast)和宏。这方面可以看看我的文章和书。抽象类和和模板 </P>
! I# f2 Z3 {7 O' q4 I* H& z7 L) N<P>的作用当然是提供一种方便的手段建构单根的类层次或者重用函数,但更重要的是,它们 </P>. C7 I& c! g! n1 |( W# ~! ~
<P>作为接口提供了简洁的、逻辑性的服务表示机制。 </P>
& g8 M  z9 D, R6 C9 w<P>  </P>- U; u& _/ l" w& R9 ~
<P>7. 语言的选择是不是很重要? </P>( y1 s1 }6 G( X& m( V  D* D5 _" U# E
<P>是,但也别指望奇迹。很多人似乎相信某一种语言能够解决他们在系统开发中遇到的几乎 </P>
, |2 M8 ~( q1 o& p( i+ ?3 S- ~5 q<P>所有问题,他们不断地去寻找完美的编程语言,然后一次次的失败,一次次的沮丧。另外 </P>1 o' [& n0 i5 Y
<P>一些人则将编程语言贬为无关紧要的细节,把大把大把的银子放在开发流程和设计方法上 </P>
: }" r$ t3 _4 {4 N6 E# g<P>,他们永远都在用着COBOL, C和一些专有语言。一种优秀的语言,例如C++,能帮助设计 </P>
1 n4 _6 q# ?9 ]7 ~<P>者和程序员做很多事情,而其能力和缺陷又能够被清楚地了解和对待。 </P>
! l: A5 o/ N/ u<P>  </P>1 W& i7 D. l& G5 }; A# Y9 U
<P>8. ANSI/ISO标准委员会是不是糟蹋了C++? </P>
, n) v3 y: N+ _+ L; k<P>当然不是!他们(我们)的工作很出色。你可以在一些细节上找些歪理来挑刺,但我个人 </P>  p+ \* e* m/ v3 {
<P>对于这种语言以及新的标准库可是欣欣然。ISO C++较之C++的以前版本更出色更有条理。 </P>. f0 g9 ~# ^. U1 j
<P>相对于标准化过程刚刚开始之初,你今天可以写出更优雅、更易于维护的C++程序。新的 </P>
& {7 ^1 X  b7 C9 d8 G4 r<P>标准库也是一份真正的大礼。由于标准库提供了strings, lists, vectors, maps以及作 </P>
& w' s* P' W: s! r( O9 D: j. Q<P>用于其上的基本算法,使用C++的方式已经发生了巨大的变化。 </P>9 ^/ ~9 a6 p. E- s! a
<P>  </P>1 x3 y& G" ]$ o% @% R+ \# E; P
<P>9. 你现在有没有想删除一些C++特性? </P>8 Z$ C# ^. {: ~+ V- D7 k% ?* q3 J
<P>没有,真的。问这些问题的人大概是希望我回答下面特性中的一个:多继承、异常、模板 </P>9 E% V( r2 {5 d  E
<P>和RTTI。但是没有它们,C++就是不完整的。在过去的N年中,我已经反复考虑过它们的设 </P>; |1 X2 d) e2 J7 x/ S: l; l
<P>计,并且与标准委员会一起改进了其细节,但是没有一个能被去掉又不引起大地震。 </P>
$ C; c; p9 V1 v2 Z+ W: X- j<P>从语言设计的角度讲,我最不喜欢的部分是与C兼容的那个子集,但又不能把它去掉,因 </P>( o' p7 R3 w1 Y# ~1 R' V+ a# A
<P>为那样对于在现实世界里工作的程序员们来说伤害太大了。C++与C兼容,这是一项关键的 </P>! m9 O8 P$ ?7 R4 G7 m2 U
<P>设计决策,绝对不是一个叫卖的噱头。兼容性的实现和维护是十分困难的,但确实使程序 </P>! j% z( e( X# h- D3 ^. y
<P>员们至今受益良多。但是现在,C++已经有了新的特性,程序员们可以从麻烦多多的C风格 </P>
5 m! M/ v4 k0 g, A: g<P>中解脱出来。例如,使用标准库里的容器类,象vector, list, map, string等等,可以 </P>
( ?, L3 k& t2 ?% Y$ P" h<P>避免与底层的指针操作技巧混战不休。 </P>
- r/ I1 ~( U8 L# _+ G! X<P>  </P>4 B, m0 ^5 {* s
<P>10. 如果不必和C兼容,你所创造的语言是不是就会是Java? </P>
9 _  h% k" ^2 D5 F; r<P>不是,差得远。如果人们非要拿C++和Java来作比较,我建议他们去阅读The Design and </P>, _" {$ k! I, \+ d  J3 V
<P>Evolution of C++,看看C++为什么是今天这个样子,用我在设计C++时遵从的原则来检验 </P>
$ f! Q( U% K  M$ l5 r+ A<P>这两种语言。这些原则与SUN的Java开发小组所持的理念显然是不同的。除了表面语法的 </P>* ~, q3 l; r9 F. v% J3 H
<P>相似性之外,C++与Java是截然不同的语言。在很多方面,Java更像Smalltalk(译者按: </P>& O& X* E$ c* T) B8 G
<P>我学习Java时用的是Sun的培训教材,里面清楚地写道:Java在设计上采用了与C++相似的 </P>  V: F$ v' V5 I2 t7 v
<P>语法,与Smalltalk相似的语义。所以可以说Java与C++是貌合神离,与Smalltalk才是心 </P>  f) O- ?  J: @
<P>有灵犀)。Java语言相对简单,这部分是一种错觉,部分是因为这种语言还不完整。随着 </P>
$ E- J0 d' \0 z- X& G<P>时间的推移,Java在体积和复杂程度上都会大大增长。在体积上它会增长两到三倍,而且 </P>% y) Y' `1 U6 j: j9 \& q
<P>会出现一些实现相关的扩展或者库。这是一条每个成功的商业语言都必须走过的发展之路 </P>
, ~) a0 f4 F' N, F) Y7 O, g2 _<P>。随便分析一种你认为在很大范围内取得了成功的语言,我知道肯定是无有例外者,而且 </P># P7 s4 B8 @6 k
<P>实际上这非常有道理。 </P>% K" B7 s' ^/ T# b( Q1 g* g
<P>上边这段话是在Java 1.1推出之前写的。我确信Java需要类似模板的机制,并且需要增强 </P>3 C, e5 Q# o) S; q) G% O6 X8 w  [
<P>对于固有类型的支持。简单地说,就是为了基本的完整性也应该做这些工作。另外还需要 </P>: ~& S6 S/ @# b) x/ d/ M
<P>做很多小的改动,大部分是扩展。1998年秋,我从James Gosling(Java语言的创始人— </P>8 `# \* E; W! J% q
<P>—译者)那里得到一份建议书,说是要在Java中增加固有类型、操作符重载以及数学计算 </P>
( \0 g, [, t  M<P>支持。还有一篇论文,是数学分析领域的世界级大师,伯克利大学的W. Kahan教授所写的 </P>
  q' W- \3 ?) c" t% q<P>How Java’s Floating-Point Hurts Everyone Everywhere(“且看Java的浮点运算如何 </P>3 B0 N  f+ I* Q9 s7 D) @* ^* ?6 S. S8 S
<P>危害了普天下的芸芸众生”——译者),揭露了Java的一些秘密。 </P>
- L$ n1 \5 \8 D" h+ d  J% {<P>我发现在电视和出版物中关于Java的鼓吹是不准确的,而且气势汹汹,让人讨厌。大肆叫 </P>
0 u# c7 t) X$ c3 J9 D5 d  ]* Q<P>嚣凡是非Java的代码都是垃圾,这是对程序员的侮辱;建议把所有的保留代码都用Java重 </P>( H  P( E8 b) e& `
<P>写,这是丧心病狂,既不现实也不负责任。Sun和他的追随者似乎觉得为了对付微软罪恶 </P>' Y; x$ y2 j* q# t
<P>的“帝国时代”,就必须如此自吹自擂。但是侮辱和欺诈只会把那些喜欢使用不同编程语 </P>
3 r$ g# n0 D& j4 k' U; i<P>言的程序员逼到微软阵营里去。 </P>. r( M! F- \9 C) k
<P>Java并非平台无关,它本身就是平台。跟Windows一样,它也是一个专有的商业平台。也 </P>
+ i0 z  U' s. r. V( i<P>就是说,你可以为Windows/Intel编写代码,也可以为Java/JVM编写代码,在任何一种情 </P>
% y* D! F$ |/ X# Z) J<P>况下,你都是在为一个属于某个公司的平台写代码,这些代码都是与该公司的商业利益扯 </P>9 e3 ?  y' Z) F# I2 e- h* J: H
<P>在一起的。当然你可以使用任何一种语言,结合操作系统的机制来编写可供JVM执行的程 </P>
9 X; i: |' o8 k& }$ z; A<P>序,但是JVM之类的东西是强烈地偏向于Java语言的。它一点也不像是通用的、公平的、 </P>& }8 g4 a8 I5 A8 s+ F9 X: G" U
<P>语言中立的VM/OS。 </P>
/ _" B! u0 w$ }/ c<P>私下里,我会坚持使用可移植的C++作大部分工作,用不同的语言作余下的工作。 </P>
& K4 K1 a+ |+ z5 W& R6 ^<P>(”Java is not platform-independent, it is the platform”,B. S的这句评语对于 </P>+ w3 q6 n+ m& x

5 |3 L# `7 ?, a% N' L- Y<P>C++用户有着很大的影响,译者在国外的几个新闻组里看到,有些C++高手甚至把这句话作 </P>
0 I% k' I  T2 T% g. F<P>为自己的签名档,以表明对Java的态度和誓死捍卫C++的决心。实际上有很多程序员不光 </P>. j% Z! y- ^6 z1 E6 C( ?1 i6 w* N" b) ?  e
<P>是把自己喜爱的语言当成一种工具,更当成一种信仰。——译者) </P>




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5