頂級(jí)Linux開發(fā)者推薦的編程書籍
Linux,毫無爭(zhēng)議的屬于 21 世紀(jì)的操作系統(tǒng)。雖然 Linus Torvalds 在建立開源社區(qū)這件事上做了很多工作和社區(qū)決策,不過那些網(wǎng)絡(luò)專家和開發(fā)者愿意接受 Linux 的原因還是因?yàn)樗吭降拇a質(zhì)量和高可用性。Torvalds 是個(gè)編程天才,同時(shí)必須承認(rèn)他還是得到了很多其他同樣極具才華的開發(fā)者的無私幫助。
就此我咨詢了 Torvalds 和其他一些頂級(jí) Linux 開發(fā)者,有哪些書籍幫助他們走上了成為頂級(jí)開發(fā)者的道路,下面請(qǐng)聽我一一道來。
熠熠生輝的 C 語(yǔ)言
Linux 是在大約上世紀(jì) 90 年代開發(fā)出來的,與它一起問世的還有其他一些完成基礎(chǔ)功能的開源軟件。與此相應(yīng),那時(shí)的開發(fā)者使用的工具和語(yǔ)言反映了那個(gè)時(shí)代的印記,也就是說 C 語(yǔ)言。可能 C 語(yǔ)言不再流行了,可對(duì)于很多已經(jīng)建功立業(yè)的開發(fā)者來說,C 語(yǔ)言是他們的第一個(gè)在實(shí)際開發(fā)中使用的語(yǔ)言,這一點(diǎn)也在他們推選的對(duì)他們有著深遠(yuǎn)影響的書單中反映出來。
Torvalds 說,“你不應(yīng)該再選用我那個(gè)時(shí)代使用的語(yǔ)言或者開發(fā)方式”,他的開發(fā)道路始于 BASIC,然后轉(zhuǎn)向機(jī)器碼(“甚至都不是匯編語(yǔ)言,而是真真正正的‘二進(jìn)制’機(jī)器碼”,他解釋道),再然后轉(zhuǎn)向匯編語(yǔ)言和 C 語(yǔ)言。
“任何人都不應(yīng)該再?gòu)倪@些語(yǔ)言開始進(jìn)入開發(fā)這條路了”,他補(bǔ)充道。“這些語(yǔ)言中的一些今天已經(jīng)沒有什么意義(如 BASIC 和機(jī)器語(yǔ)言)。盡管 C 還是一個(gè)主流語(yǔ)言,我也不推薦你從它開始。”
并不是他不喜歡 C。不管怎樣,Linux 是用 GNU C 語(yǔ)言寫就的。“我始終認(rèn)為 C 是一個(gè)偉大的語(yǔ)言,它有著非常簡(jiǎn)單的語(yǔ)法,對(duì)于很多方向的開發(fā)都很合適,但是我懷疑你會(huì)遇到重重挫折,從你的第一個(gè)‘Hello World’程序開始到你真正能開發(fā)出能用的東西當(dāng)中有很大一步要走”。他認(rèn)為,用現(xiàn)在的標(biāo)準(zhǔn),如果作為入門語(yǔ)言的話,從 C 語(yǔ)言開始的代價(jià)太大。
在他那個(gè)時(shí)代,Torvalds 的唯一選擇的書就只能是 Brian W. Kernighan 和 Dennis M. Ritchie 合著的《C 編程語(yǔ)言,第二版》,它在編程圈內(nèi)也被尊稱為 K&R。“這本書簡(jiǎn)單精煉,但是你要先有編程的背景才能欣賞它”,Torvalds 說到。
Torvalds 并不是唯一一個(gè)推薦 K&R 的開源開發(fā)者。以下幾位也同樣引用了這本他們認(rèn)為值得推薦的書籍,他們有:Linux 和 Oracle 虛擬化開發(fā)副總裁 Wim Coekaerts;Linux 開發(fā)者 Alan Cox;Google 云 CTO Brian Stevens;Canonical 技術(shù)運(yùn)營(yíng)部副總裁 Pete Graner。
如果你今日還想同 C 語(yǔ)言較量一番的話,Samba 的共同創(chuàng)始人 Jeremy Allison 推薦《C 程序設(shè)計(jì)新思維》。他還建議,同時(shí)也去閱讀一本比較舊但是寫的更詳細(xì)的《C 專家編程》和有著 20 年歷史的《POSIX 多線程編程》。
如果不選 C 語(yǔ)言, 那選什么?
Linux 開發(fā)者推薦的書籍自然都是他們認(rèn)為適合今時(shí)今日的開發(fā)項(xiàng)目的語(yǔ)言工具。這也折射了開發(fā)者自身的個(gè)人偏好。例如,Allison 認(rèn)為年輕的開發(fā)者應(yīng)該在《Go 編程語(yǔ)言》和《Rust 編程》的幫助下去學(xué)習(xí) Go 語(yǔ)言和 Rust 語(yǔ)言。
但是超越編程語(yǔ)言來考慮問題也不無道理(盡管這些書傳授了你編程技巧)。今日要做些有意義的開發(fā)工作的話,要從那些已經(jīng)完成了 99% 顯而易見工作的框架開始,然后你就能圍繞著它開始寫腳本了
, Torvalds 推薦了這種做法。
“坦率來說,語(yǔ)言本身遠(yuǎn)遠(yuǎn)沒有圍繞著它的基礎(chǔ)架構(gòu)重要”,他繼續(xù)道,“可能你會(huì)從 Java 或者 Kotlin 開始,但那是因?yàn)槟阆霝樽约旱氖謾C(jī)開發(fā)一個(gè)應(yīng)用,因此安卓 SDK 成為了最佳的選擇,又或者,你對(duì)游戲開發(fā)感興趣,你選擇了一個(gè)游戲開發(fā)引擎來開始,而通常它們有著自己的腳本語(yǔ)言”。
這里提及的基礎(chǔ)架構(gòu)包括那些和操作系統(tǒng)本身相關(guān)的編程書籍。 Garner 在讀完了大名鼎鼎的 K&R 后又拜讀了 W. Richard Steven 的《Unix 網(wǎng)絡(luò)編程》。特別是,Steven 的《TCP/IP 詳解,卷1:協(xié)議》在出版了 30 年之后仍然被認(rèn)為是必讀之書。因?yàn)?Linux 開發(fā)很大程度上和和網(wǎng)絡(luò)基礎(chǔ)架構(gòu)有關(guān),Garner 也推薦了很多 O'Reilly 在 Sendmail、Bash、DNS 以及 IMAP/POP 等方面的書。
Coekaerts 也是 Maurice Bach 的《UNIX 操作系統(tǒng)設(shè)計(jì)》的書迷之一。James Bottomley 也是這本書的推崇者,作為一個(gè) Linux 內(nèi)核開發(fā)者,當(dāng) Linux 剛剛問世時(shí) James 就用 Bach 的這本書所傳授的知識(shí)將它研究了個(gè)底朝天。
軟件設(shè)計(jì)知識(shí)永不過時(shí)
盡管這樣說有點(diǎn)太局限在技術(shù)領(lǐng)域。Stevens 還是說到,“所有的開發(fā)者都應(yīng)該在開始鉆研語(yǔ)法前先研究如何設(shè)計(jì),《設(shè)計(jì)心理學(xué)》是我的最愛”。
Coekaerts 喜歡 Kernighan 和 Rob Pike 合著的《程序設(shè)計(jì)實(shí)踐》。這本關(guān)于設(shè)計(jì)實(shí)踐的書當(dāng) Coekaerts 還在學(xué)校念書的時(shí)候還未出版,他說道,“但是我把它推薦給每一個(gè)人”。
不管何時(shí),當(dāng)你問一個(gè)長(zhǎng)期從事于開發(fā)工作的開發(fā)者他最喜歡的計(jì)算機(jī)書籍時(shí),你遲早會(huì)聽到一個(gè)名字和一本書:Donald Knuth 和他所著的《計(jì)算機(jī)程序設(shè)計(jì)藝術(shù)(1-4A)》。VMware 首席開源官 Dirk Hohndel,認(rèn)為這本書盡管有永恒的價(jià)值,但他也承認(rèn),“今時(shí)今日并非極其有用”。(LCTT 譯注:不代表譯者觀點(diǎn))
讀代碼。大量的讀。
編程書籍能教會(huì)你很多,也請(qǐng)別錯(cuò)過另外一個(gè)在開源社區(qū)特有的學(xué)習(xí)機(jī)會(huì):《代碼閱讀方法與實(shí)踐》。那里有不可計(jì)數(shù)的代碼例子闡述如何解決編程問題(以及如何讓你陷入麻煩……)。Stevens 說,談到磨煉編程技巧,在他的書單里排名第一的“書”是 Unix 的源代碼。
“也請(qǐng)不要忽略從他人身上學(xué)習(xí)的各種機(jī)會(huì)。” Cox 道,“我是在一個(gè)計(jì)算機(jī)俱樂部里和其他人一起學(xué)的 BASIC,在我看來,這仍然是一個(gè)學(xué)習(xí)的最好辦法”,他從《精通 ZX81 機(jī)器碼》這本書和 Honeywell L66 B 編譯器手冊(cè)里學(xué)習(xí)到了如何編寫機(jī)器碼,但是學(xué)習(xí)技術(shù)這點(diǎn)來說,單純閱讀和與其他開發(fā)者在工作中共同學(xué)習(xí)仍然有著很大的不同。
Cox 說,“我始終認(rèn)為最好的學(xué)習(xí)方法是和一群人一起試圖去解決你們共同關(guān)心的一些問題并從中找到快樂,這和你是 5 歲還是 55 歲無關(guān)”。
最讓我吃驚的是這些頂級(jí) Linux 開發(fā)者都是在非常底層級(jí)別開始他們的開發(fā)之旅的,甚至不是從匯編語(yǔ)言或 C 語(yǔ)言,而是從機(jī)器碼開始開發(fā)。毫無疑問,這對(duì)幫助開發(fā)者理解計(jì)算機(jī)在非常微觀的底層級(jí)別是怎么工作的起了非常大的作用。
那么現(xiàn)在你準(zhǔn)備好嘗試一下硬核 Linux 開發(fā)了嗎?Greg Kroah-Hartman,這位 Linux 內(nèi)核穩(wěn)定分支的維護(hù)者,推薦了 Steve Oualline 的《實(shí)用 C 語(yǔ)言編程》和 Samuel harbison 與 Guy Steels 合著的《C 語(yǔ)言參考手冊(cè)》。接下來請(qǐng)閱讀如何進(jìn)行 Linux 內(nèi)核開發(fā),到這時(shí),就像 Kroah-Hartman 所說,你已經(jīng)準(zhǔn)備好啟程了。
于此同時(shí),還請(qǐng)你刻苦學(xué)習(xí)并大量編碼,最后祝你在跟隨頂級(jí) Linux 開發(fā)者腳步的道路上好運(yùn)相隨。