数学建模社区-数学中国
标题:
[转帖]经典之后的经典
[打印本页]
作者:
matrixer
时间:
2005-1-10 11:44
标题:
[转帖]经典之后的经典
经典之后的经典
/ P% \" J" g3 \5 d4 C
——写在C++图书出版史上又一部经典著作问世之前
/ b5 |5 Y: l5 B0 i' W2 {* T+ G$ S
1 {% ~1 q% F8 \0 m
C++图书界沉寂久矣!
$ d: _3 E! ?# Y0 n, G: n1 ?5 q
+ K1 [+ B9 {: p8 J$ L2 y
至少我是这么认为的。国内引进第一批C++经典书籍的时候我是亲历的。感觉真是“忽如一夜春风来,千树万树梨花开”。别误会,我说的这个第一批并非《C++ Programming Language》《C++ Primer》这种经典中的经典。而是说诸如《Exceptional C++》《More Exceptional C++》《Effective&More Effective C++》《C++ Gotchas》《Generic Programming and the STL》《The C++ Standard Library》《C++ Templates》《Morden C++ Design》等。其中《Modern C++ Design》是最为激动人心的著作。学泛型而不读该著作就好像学算法不读D.E的《The Art of Compute Programming vol.1.2.3》一样,无法达到更高的境界。我只记得当时拿到这本书从早晨9点一直看到晚上22点,两顿饭都没有吃,如痴如醉。正因为这本书太经典,也太前卫了,所以我看完心里就暗暗的下了个结论“C++图书界将很久不会出现这样激动人心的著作了”。果然,后来出的一些如《Accelerate C++》《Applied C++》《C++ Network Programming vol.1.2》等,虽然也堪入经典之列,但是毕竟没有令人十分振奋的内容了。
7 K+ X9 b6 E! o) A! }( N9 E5 t
: C" t5 g; P6 I5 ]9 U+ j
然而,C++泛型技术的发展却一刻也没有停止过,boost库的不断更新将C++泛型技术逐渐推动到了一个新的高峰,原先在《Modern C++ Design》中的有些前卫有些学院派的技术到了boost库中终于和实践紧密结合到了一起,泛型的抽象本质发挥了其惊人的力量,于是boost库里出现了一个又一个具有高度可复用性和定制性的泛型构件。泛型通过boost库终于渐渐贴近了程序员的生活。
" W2 C' A4 w+ P" N$ K0 I5 O
" z5 D% D! j n5 g2 |8 e
如果说C++泛型是那只压在五行山下的孙猴子,那么《Modern C++ Design》就揭开了山上的封印,释放了这猴头惊人的力量,而boost库则是孙悟空头上的那道金箍,约束并引导着它向正确的方向走,做正确的事。虽然有这道金箍,但它的力量却一点也没有削弱,甚至更强,只不过在被磨掉棱角的同时日趋成熟了而已。
. _8 M# y7 v' @! k. o' i0 L; q
# W9 ? D( t/ h# _' k: _% O
然而,遗憾的是,虽然boost库中随处可见精致的泛型应用,可以说是一本源码教科书,正如Linux源代码之与程序员,但是“没有三两三,别想过梁山”,并非每个人都能够读懂其源代码,甚至一个对泛型颇为了解的程序员也会在其中迷途难返。这是因为boost库为了在大部分主流编译器上都能通过编译,做了很多的workaround,并且,为了节省代码量,boost库中随处可见大片大片的宏,这些宏就像迷宫,源代码的迷宫。这两个原因都使得boost的源代码可读性较差。
) t: A0 n& L. o- S% f" M
8 K3 ^* r( v1 Q# ?! y) c* j
因此,boost库虽然贴近了程序员,boost库的源代码却愈发远离了程序员。
( r1 p+ F# z6 d2 p2 e& L/ x" I; a) G
2 L) m( h0 S) r* ?' Q
但是,在C++泛型领域已经登堂入室,欲更进一步,一窥堂奥者却非得阅读像boost这样经典的源代码不可。“熟读唐诗三百首,不会吟诗也会吟”。
4 }. N! h, T3 I0 c
/ D( I1 N' n C) X9 \
虽然boost库的源代码的可读性较差,但也并非极差,如果有人事先为你透彻讲解boost库中的泛型运用和设计理念,相信你一定会在阅读时游刃有余。
% X8 P& X8 D& B2 a# L- [
: |4 A/ s4 e* F; {6 s# O5 u
这就是了——一本即将出版的经典之作,由boost的发起者之一,C++标准委员会的成员David Abraham以及另一位boost成员Aleksey Gurtovoy合著的——《C++ Template Metaprogramming:Concepts,Tools,and Techniques from Boost and Beyond》。
- z8 n- M( \% T# M2 Q# P" X- U: t
. `- k+ I* d) x
对于这么一本势必成为经典的书,我实在惶于评价,还是引用其主页上面的一段话吧:
+ i& V) i w. m7 b5 L: H4 T
* j$ Y) `# m, l& m: Q; O6 {5 z
& w0 D+ D4 \7 x4 I3 V
B' b& o* x: C; k- k3 `
这本讲述C++模板元编程的书将赋予C++用户空前的强大能力,并使这门技术成为程序员手中真正实用的一门技术。
. f1 a2 _/ f' e$ K0 S6 K
" n) G# J7 ]# b! M4 y; v7 I
This book covers C++ Template Metaprogramming in a way that provides unprecedented capability to the C++ power-user, and delivers practical metaprogramming into the hands of the everyday programmer.
8 \ O( b/ y$ u& b; B2 `" d! t" U0 s
U: Y% I2 s9 B/ X/ g' f
6 Y) ^) z0 Y: W4 A9 [
- Q9 [+ b$ W" S2 q' i4 Y5 H% g
一直以来,C++泛型似乎总处于一种奇怪的位置,有人说它太学院派,有人认为那太遥远,现在还用不到它,有人认为那是库的设计者的事情,与程序员关系不大。更有人持“不敢高攀”的态度。其实这些都是错误的态度,泛型是一门由来已久的思想,其核心理念是抽象,并没有什么神秘之处。与面向对象提供的二进制复用相比,泛型的代码提供了源码级的复用,一个具有更强的动态特性,一个具有更强的类型安全性和效率,两者互补才能发挥最大的力量。已经出版的很多关于C++泛型的经典书籍其实已经很好的介绍了这一点。只不过,关于C++泛型,还有一门可以独立出来的技术——模板元编程。而这恰恰是令泛型构件更具表达力和自由度的技术。甚至也可以说是boost库的基石之一(除了部分对泛型依赖不强的组件如Regex等例外)。所以,显而易见这是一门非常重要的技术,这一点从《Generative Programming》一书中也可看出。
6 ] E) y5 i" Z( {; r( v9 m. }, K
8 L ~6 `. V# |4 [1 ]
然而,对于这门可以独立出来的技术,目前我们所看到的只是一些零星的描述,《C++ Templates》里面虽有一整章描述metaprogram,但对于渴求知识者仍如隔靴搔痒,不能尽兴。不过,这种情况就快过去了,《C++ Template Metaprogramming》将会系统的讲述C++模板元编程技术,将这门原先只是大师们手中的利器的神秘技术带到普通程序员的手中,赋予普通程序员惊人的力量。
$ M8 r' W0 B! M
/ ]% G6 N: {3 |, [3 x
如果说《Modern C++ Design》是C++泛型书籍上的经典之作(它的确是),那么这本即将道来的《C++ Template Metaprogramming》将是经典之后的又一次经典!
0 A8 `* O# }4 v. x6 }
; H6 S3 c2 X# N
) m. d! P) C% L. F P" E- q
9 m4 U2 t5 C6 T" Z6 h
作者开放了该书的第三章和附录A。虽然只有两章,但是精彩纷呈,绝对值得一读。下面是我的翻译,一是出于自己的兴趣,二是方便读者。
% V1 b( \7 t' u0 m$ D, H" R. A/ W
+ j; T: h' r/ p# g+ b
, [' U4 D+ E7 U2 d0 Q
. F6 t$ b' ]5 k3 u6 ?
第三章 深度探索元函数
- K& Q/ A0 D) f+ A- d1 K6 a' w
0 A3 \+ W* S% O6 `( E" V3 X7 U
<a href="http://blog.csdn.net/pongba/archive/2004/09/01/90642.aspx" target="_blank" >http://blog.csdn.net/pongba/archive/2004/09/01/90642.aspx</A>
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5