Posted on 2007-03-29 10:22
北緯91℃ 閱讀(283)
評(píng)論(0) 編輯 收藏 引用 所屬分類:
C++
C語(yǔ)言天生就與開(kāi)放結(jié)緣。C最初是作為UNIX的系統(tǒng)編程語(yǔ)言而流行起來(lái)的,而UNIX可以被認(rèn)為是第一個(gè)產(chǎn)生重大影響的“開(kāi)源”軟件。隨著UNIX的流行,C語(yǔ)言逐漸被人們認(rèn)識(shí)和喜愛(ài)。很快的,在各個(gè)平臺(tái)上C語(yǔ)言都成為了流行的甚至是統(tǒng)治性的程序設(shè)計(jì)語(yǔ)言。
大約到1980年代中期,C已經(jīng)成為人類歷史上第一種工業(yè)級(jí)程序設(shè)計(jì)世界語(yǔ)。很多人都知道,正是C這樣一種世界語(yǔ)的出現(xiàn),才使開(kāi)源運(yùn)動(dòng)的出現(xiàn)和最初發(fā)展成為可能,從這個(gè)意義上講,說(shuō)C語(yǔ)言是開(kāi)源運(yùn)動(dòng)之母并不十分過(guò)分。但人們不太能夠認(rèn)識(shí)到的是,事實(shí)上C語(yǔ)言統(tǒng)治地位的獲得,卻也是早期開(kāi)放軟件運(yùn)動(dòng)的直接結(jié)果。多數(shù)人在回顧這段歷史的時(shí)候,經(jīng)常會(huì)感染中國(guó)文人的不嚴(yán)肅的浪漫主義史觀,喜歡把C語(yǔ)言的成功歸結(jié)為漢高祖斬白蛇般的天賦神格,描述為遙想公瑾當(dāng)年,談笑間檣櫓灰飛煙滅的輕飄飄。
然而如果我們對(duì)歷史作一些細(xì)致的調(diào)查,我們會(huì)發(fā)現(xiàn)C語(yǔ)言絕非有什么天命,而只不過(guò)是幸運(yùn)地扒上了早期開(kāi)放運(yùn)動(dòng)的快車而已。在C語(yǔ)言“小人乍富”的那幾年,也還有其它不少程序設(shè)計(jì)語(yǔ)言具有高性能、可移植、系統(tǒng)開(kāi)發(fā)能力強(qiáng)的特點(diǎn),決不是只有C骨骼特異,貌若天仙。如果Pascal也能借助一個(gè)像UNIX那樣的開(kāi)放的幽靈在歐美大學(xué)校園里徘徊,那么我們今天很可能要把begin和end直接映射到鍵盤上。
如果IBM不是在1970年代極端保守地把一種叫做PL/X的語(yǔ)言牢牢地限定在自己的研究所里,也許整個(gè)程序員社群的圖騰就不是貝爾試驗(yàn)室的那兩個(gè)大胡子,而是小沃森實(shí)驗(yàn)室里的IBM某院士。事實(shí)上,C語(yǔ)言的成功,更須拜開(kāi)放軟件運(yùn)動(dòng)之時(shí)勢(shì)所賜,或者更確切地說(shuō),C與開(kāi)放軟件是一對(duì)共生體,它們相互扶持,相互成就,共同成長(zhǎng)興旺,共同創(chuàng)造歷史。
根深自然葉茂。今天C語(yǔ)言體系內(nèi)所擁有的開(kāi)放資源,無(wú)論是數(shù)量和質(zhì)量,還是豐富性、多樣性、創(chuàng)新性、可靠性、重要性,都是其它任何開(kāi)發(fā)技術(shù)體系所無(wú)法望其項(xiàng)背的。豐富對(duì)于開(kāi)發(fā)者是好事,但對(duì)于寫(xiě)資源介紹性文章的作者來(lái)說(shuō),則是絕對(duì)的壞事。想要對(duì)C語(yǔ)言體系中的開(kāi)放資源做一個(gè)介紹,哪怕只是一次白描,也決不是一個(gè)人、一本書(shū)所能容納的,更遠(yuǎn)遠(yuǎn)不是雜志中的一篇文章所能及的。因此在本文中,對(duì)于C語(yǔ)言開(kāi)放資源的介紹是以一種蜻蜓點(diǎn)水的姿態(tài)進(jìn)行的。
相比之下,C++語(yǔ)言在開(kāi)源世界中的分量,與C語(yǔ)言相比就相去甚遠(yuǎn)了。作為對(duì)照,C++語(yǔ)言在工業(yè)界的實(shí)際地位,如果不是比C更重要的話,至少也是與C在同一個(gè)層次上。考慮到這一點(diǎn),在開(kāi)源領(lǐng)域中兩兄弟的這種差距就令人感到非常震驚。如果說(shuō)在2000年以前,由于C++在工業(yè)界的統(tǒng)治地位,這種差距對(duì)C++的影響還不大的話,今天,C++在開(kāi)源領(lǐng)域里薄弱的基礎(chǔ)就非常要命了。現(xiàn)在在開(kāi)發(fā)者社群中,“C語(yǔ)言萬(wàn)壽無(wú)疆,C++無(wú)壽無(wú)疆”的說(shuō)法得到不少人的支持,其根本原因之一就在于C++在開(kāi)源運(yùn)動(dòng)中的地位遠(yuǎn)遜于C。究其原因,歸根到底是因?yàn)榫帉?xiě)高質(zhì)量、可復(fù)用而又拳拳服膺的C++程序庫(kù)實(shí)在是一件太困難的事情。一方面,大量的C++開(kāi)源項(xiàng)目質(zhì)量不佳,而且經(jīng)常以一種粗暴的方式要求使用者改變自己程序的風(fēng)格,另一方面,一旦有人完成了一個(gè)可用的C++項(xiàng)目或者程序庫(kù),他必須具有極其彪悍的意志才能夠咬著牙把這樣的項(xiàng)目奉獻(xiàn)給開(kāi)源社群——不僅因?yàn)槭チ丝赡艿慕疱X上的回報(bào),更因?yàn)榭赡芤鎸?duì)著暴風(fēng)雨般的批評(píng)和鄙視。總之,諸多的原因使得開(kāi)源文化未能在C++中深深扎根。
然而,畢竟C++是一種稱霸一時(shí)的語(yǔ)言,C++社群的規(guī)模、強(qiáng)悍和創(chuàng)造力,仍然是很多其它新興語(yǔ)言社群難以相比的。特別是在標(biāo)準(zhǔn)C++制定之后,C++ 編程風(fēng)格有了明確的指導(dǎo)思路,開(kāi)源項(xiàng)目也就大大繁榮起來(lái)。雖然時(shí)間還不長(zhǎng),但是已經(jīng)有一些令人欣慰的成果。這些成果也就構(gòu)成了寫(xiě)作本文的基本動(dòng)機(jī)和素材。
就重要性而言,開(kāi)源程序庫(kù)和工具集對(duì)于C++甚至比對(duì)C還要重要得多。因?yàn)閷?shí)踐證明,沒(méi)有良好的基礎(chǔ)設(shè)施支持,C++開(kāi)發(fā)成功的可能性異乎尋常的低。其根本原因是,用C++寫(xiě)優(yōu)秀的程序庫(kù)非常非常難,而一旦有了這樣的程序庫(kù),在其基礎(chǔ)上寫(xiě)應(yīng)用程序就相當(dāng)容易了。同時(shí),C++的特點(diǎn)又要求基礎(chǔ)設(shè)施的源代碼必須開(kāi)放,因此,C++程序庫(kù)對(duì)于開(kāi)發(fā)者來(lái)說(shuō)意義非常重大。
我們可以更進(jìn)一步探究開(kāi)源C++程序庫(kù)對(duì)于C++開(kāi)發(fā)的重要意義。用C++編寫(xiě)可復(fù)用程序庫(kù)時(shí)所需要的思想方法和技術(shù)風(fēng)格,與用C++編寫(xiě)應(yīng)用程序時(shí)所需要的思想方法和技術(shù)風(fēng)格之間存在相當(dāng)大的差異和差距。前者所需要的高超技術(shù)、豐富經(jīng)驗(yàn)和良好的權(quán)衡能力,是很少有人能具備的。在所有程序設(shè)計(jì)語(yǔ)言中,你恐怕找不出第二種語(yǔ)言像C++那樣,對(duì)于程序庫(kù)作者的要求如此之高,以至于遠(yuǎn)遠(yuǎn)超過(guò)了一般“熟練”C++開(kāi)發(fā)者的平均水平。在Lisp中,語(yǔ)言、庫(kù)和程序根本就是一回事,每一個(gè)程序員寫(xiě)的代碼都可以看成是語(yǔ)言本身的擴(kuò)充。
在Java、C、 Perl、Python、Ruby中,一個(gè)優(yōu)秀的應(yīng)用程序開(kāi)發(fā)者在積累一定經(jīng)驗(yàn)之后,不難寫(xiě)出高質(zhì)量的可復(fù)用代碼。而在C++中,這種事情是非常罕見(jiàn)的,即使是天資卓越、經(jīng)驗(yàn)豐富的大師級(jí)人物,也需要花費(fèi)多年的打磨,歷經(jīng)幾次反復(fù),才能夠最終推出受到一致認(rèn)可的可復(fù)用程序庫(kù)。此道之難,難于上青天,以至于 Andrei Alexandrescu感嘆道,十幾歲的少年天才滿目皆是,滿鬢斑白的優(yōu)秀程序庫(kù)設(shè)計(jì)者鳳毛麟角。而在另一個(gè)地方,一本C++可復(fù)用技術(shù)圖書(shū)的作者總結(jié)道,所謂可復(fù)用的C++程序庫(kù),不可能是設(shè)計(jì)出來(lái)的,只可能是復(fù)用出來(lái)的。然而,一旦這樣的程序庫(kù)構(gòu)造出來(lái)并且為人們熟悉,那么就會(huì)大大地簡(jiǎn)化應(yīng)用程序的開(kāi)發(fā)。這也就是為什么在2000年后,Bjarne Stroustrup無(wú)數(shù)次地呼吁社群專注程序庫(kù)的開(kāi)發(fā)。他很清楚,只有程序庫(kù)能夠救C++,只有程序庫(kù)能夠發(fā)展C++。
現(xiàn)在我們知道,用來(lái)寫(xiě)C++程序庫(kù)所需要的技術(shù),與用來(lái)寫(xiě)C++應(yīng)用程序所需要的技術(shù)存在很大的差別。這已經(jīng)比較糟糕了。更糟糕的是,一般的C++開(kāi)發(fā)者根本分不清這中間的差別,他們?cè)陂_(kāi)發(fā)中往往既不是一個(gè)稱職的程序庫(kù)開(kāi)發(fā)者,也不是一個(gè)單純的應(yīng)用開(kāi)發(fā)者。他們一邊想著完成手頭的工作,一邊琢磨如何能夠?qū)懗龈哔|(zhì)量的基礎(chǔ)庫(kù)和框架,為萬(wàn)世開(kāi)太平。如果說(shuō)C語(yǔ)言是一把輕快的小匕首,遇誰(shuí)都是進(jìn)身猛刺,血濺一尺,那么這種C++的使用方式無(wú)異于左手打鐵鑄兵,右手揮劍刺秦,這種精神分裂的狀態(tài)直接將很多項(xiàng)目變成了既超期超支又質(zhì)量低劣的垃圾。
認(rèn)識(shí)到這樣的事實(shí)之后,C++程序員應(yīng)當(dāng)以更理性的態(tài)度來(lái)看待自己的工作。大部分情況下,你所需要做的是尋找一些可以互相合作的、穩(wěn)定可靠的開(kāi)源程序庫(kù),然后在其基礎(chǔ)之上,面向目標(biāo),使用盡可能簡(jiǎn)樸的技術(shù),專心專意地進(jìn)行應(yīng)用開(kāi)發(fā),把那些復(fù)雜精妙的語(yǔ)言技巧和“可復(fù)用”之類的想法扔到Java國(guó)去。唯其如此,你才可能更高效地開(kāi)發(fā)出好的應(yīng)用軟件,而且會(huì)逐漸積累和重構(gòu)出真正可復(fù)用的軟件。