Linux背后的思想
1.Linus Torvalds
Linus Torvalds對(duì)技術(shù)進(jìn)行了兩次更改,第一個(gè)是支持Internet的Linux內(nèi)核,第二個(gè)是Git,它是全世界開(kāi)發(fā)人員使用的源代碼管理系統(tǒng)。 在接受TED采訪(fǎng)時(shí),Torvalds以開(kāi)放的態(tài)度講述了他獨(dú)特的工作風(fēng)格和個(gè)性特征。 Torvalds說(shuō):“我不是夢(mèng)想家,我是工程師,我很高興與夢(mèng)想家在一起,他們仰望著天空說(shuō),”我想去那里。“但是我是那種腳踏實(shí)地的人,我只想填補(bǔ)我面前的空缺,不要讓自己失望,這就是我。”
2.關(guān)于開(kāi)源
Linus Torvalds說(shuō):
Linux并不是一個(gè)合作的產(chǎn)物,它是我一系列項(xiàng)目中的一個(gè),純粹出于自己當(dāng)時(shí)的需要,部分原因是我需要得到結(jié)果,但更重要的原因是我享受編程。這段旅程的終點(diǎn),在25年后的今天(2016),我們?nèi)晕催_(dá)到。當(dāng)年我只是想做一個(gè)完全屬于自己的項(xiàng)目,我壓根就沒(méi)想過(guò)開(kāi)源這件事。但在那之后,隨著項(xiàng)目越來(lái)越大, 你會(huì)開(kāi)始想讓別人知道。感覺(jué)就像“哇,快來(lái)看看我的成果!”
成千上萬(wàn)的人想?yún)⑴c進(jìn)來(lái)(Linux內(nèi)核項(xiàng)目),但很多時(shí)候,我成為了那個(gè)斷點(diǎn),我無(wú)法讓自己跨出那一步,同上千人合作。
因此Git是我的第二個(gè)大項(xiàng)目,它存在的意義就是維護(hù)我的第一個(gè)大項(xiàng)目。事實(shí)上這就是我的工作方式。我編程并不是為了…,我編程是因?yàn)楹猛?,但我也想做一些有意義的事情,因此我設(shè)計(jì)每一個(gè)程序僅僅是因?yàn)槲易约盒枰?/p>
而我喜歡開(kāi)源軟件的一點(diǎn)就是,它能讓形形色色的人在一起合作。我們不必相互喜歡,有時(shí)候我們甚至互相討厭。是真的,我們經(jīng)常吵得不可開(kāi)交。
科學(xué)界的開(kāi)源顯然是一種回歸,科學(xué)最初是開(kāi)源的。但之后變得越來(lái)越封閉,只存在那些昂貴的科學(xué)期刊上。開(kāi)源讓科學(xué)回歸了,我們有了arXiv和開(kāi)放期刊。
小編有話(huà)說(shuō):
Linux并不是選擇了開(kāi)源,只是因?yàn)殚_(kāi)源恰好是Linux需要的。就如Linus Torvalds所說(shuō):“純粹出于自己當(dāng)時(shí)的需要。”
Linus Torvalds是睿智的,做好自己能控制的。
開(kāi)源不僅僅代表源代碼的開(kāi)放,開(kāi)源更是一種工作方式,一種教育方式。因?yàn)橛辛碎_(kāi)源,我們多了一種更好的合作共贏的工作方式;因?yàn)橛辛碎_(kāi)源,讓更多從業(yè)者和學(xué)生能夠?qū)W習(xí)到更好的技術(shù)。
3.代碼的品味
Linus Torvalds說(shuō):
有時(shí)候你可以換個(gè)角度看問(wèn)題,重寫(xiě)代碼,排除特例,完美覆蓋所有情況,這就是好的代碼。同時(shí)也很簡(jiǎn)單,這是最基本的原則。細(xì)節(jié)非常重要。對(duì)我來(lái)說(shuō),我愿意與之共事的人,必須有好的品位。
采訪(fǎng)中Linus Torvalds對(duì)比了以下2個(gè)函數(shù):
小編有話(huà)說(shuō):
大牛們總是對(duì)自己嚴(yán)格要求,不僅僅是要實(shí)現(xiàn)功能,并且要優(yōu)雅的實(shí)現(xiàn)。下面我們來(lái)看看采訪(fǎng)中Linus Torvalds對(duì)比的兩段代碼:
1.不怎么漂亮的代碼
上面的代碼,需要區(qū)分要移除的成員是否為鏈表的頭一個(gè)成員。需要單獨(dú)處理特例情況(要移除的成員為鏈表的頭一個(gè)成員)。這個(gè)函數(shù)比較好理解,這里小編就不做更多的解釋了,如有疑問(wèn),請(qǐng)?zhí)砑有【幬⑿沤涣鳌?/p>
2. 好的代碼
該代碼不需要處理特殊情況,而且程序整體更加有序、優(yōu)雅。其實(shí)現(xiàn)原理為:指針變量indirect保存的是鏈表成員結(jié)構(gòu)體中的next成員的地址(head指針也可這樣看),如下圖所示:
所以變量*indirect就相當(dāng)于是前一個(gè)鏈表成員的next成員(相對(duì)于要移除的成員來(lái)說(shuō))。當(dāng)找到要移除的成員后,進(jìn)行如下操作即可:
*indirect = entry->next;