英文原文:My brain can’t handle OOP anymore
今天我意識到已經(jīng)沒(méi)有什么比面向對象編程更困擾我了。尤其是 Java。人們確實(shí)都在用它嗎???
— Swizec (@Swizec) April 29, 2012
前幾個(gè)星期我在做一個(gè)編譯器的作業(yè)——語(yǔ)義分析部分要用到面向對象,簡(jiǎn)直是噩夢(mèng)。需要用訪(fǎng)問(wèn)者模式去遍歷樹(shù),并做些奇怪的事情。
這讓我一度想在角落里蜷縮起來(lái),在臥室里邊自言自語(yǔ),邊來(lái)回搖晃。這讓River Tam在逃離房間前大喊:“太擁擠了!”
OOP像什么
神經(jīng)???
在面向對象編程里,一切都攪在一起。函數和數據綁在一起,所有的一切都相互依賴(lài),當你要調用一個(gè)函數時(shí)根本就不知道這個(gè)函數用來(lái)做什么。
而且這是在假設單個(gè)對象是沒(méi)有什么錯誤的情況下的。不然誰(shuí)又知道會(huì )發(fā)生什么呢?這個(gè)世界就要爆炸了!
面向對象寫(xiě)出來(lái)的軟件根本沒(méi)辦法理解。我曾經(jīng)覺(jué)得我可以理解,但我寫(xiě)了幾個(gè)月的面向過(guò)程的程序后,我發(fā)現我已經(jīng)沒(méi)有腦力去理解面向對象的代碼了。太亂了。
當你要使用單例模式時(shí),并且一個(gè)對象要使用另外一個(gè)對象時(shí)。讓我給你看個(gè)實(shí)例:
foo: object { i: private integer = 0; add: function (a:integer) { i += a; return i; }}/* lots of code happens here, foo has been passed around, things happened *//* foo is not a singleton though, just used a lot */a:integer = foo.add(5); // What is the value of a?要回答這個(gè)簡(jiǎn)單的問(wèn)題需要知道一切:foo的整個(gè)執行歷史,整個(gè)代碼。是你命名的,你必須記住名字。
噢,我有提到bar類(lèi)嗎?它依賴(lài)于foo。哦耶,它們去年因為利益而成為了朋友。相當有趣。盡管bar曾經(jīng)用baz騙過(guò)foo(譯者注:foo和bar在計算機世界里常被用于例子中的變量名,函數名。)沒(méi)有人知道foo將會(huì )如何反擊!
面向過(guò)程編程
在@sbelak 的數次激勵下,我在兩年前開(kāi)始學(xué)習面向過(guò)程編程。
有人說(shuō)面向過(guò)程可擴展性更高,幾乎不需要更多的代價(jià)就可以擴展到多處理器上,清晰的代碼,可以寫(xiě)出更容易開(kāi)發(fā)、更容易維護、更少bug的軟件。
我雖然沒(méi)有體會(huì )到所有的這些好處,但我現在已經(jīng)可以用一種新的思維來(lái)思考我寫(xiě)的代碼了,那是一種更容易理解的方法。
最初寫(xiě)函數式程序時(shí),就像對我進(jìn)行前腦切除手術(shù)一樣痛苦,就像用熱紅的烙鐵燒我的腳一般讓我掙扎不堪。你確定這里不需要用循環(huán)語(yǔ)句?但我需要變量,不是嗎?至少要一點(diǎn)可變性吧?真的嗎?不需要嗎?這就像一種儀式,任何時(shí)候你們都可能會(huì )跳起來(lái),對我說(shuō)“給你個(gè)驚喜”,然后開(kāi)始嘲笑我。
但我堅持下來(lái)了。雖然我的代碼看上去很可怕,但我愛(ài)上了它了。
函數式代碼首先吸引我的地方就是在于寫(xiě)python函數時(shí)僅需要傳遞數據。不需要儲存中間變量,僅僅傳遞一個(gè)函數的結果給另外一個(gè)函數。
誰(shuí)又在乎中間的步驟?我關(guān)心的僅僅是這一大塊代碼創(chuàng )建了X,而不是它首先做了Y,然后Z,然后把A和B合并成了X。
當然,你當然可以定義一個(gè)X的函數,將Y,Z,A,B都包含在內,但為什么要創(chuàng )建一個(gè)僅僅被調用過(guò)一次的函數呢??jì)H僅像這樣
X = A+B(Y(Z)) 不是更好么?
數據的瀑布
普萊維斯瀑布
我現在思考代碼的方式是就像是數據的瀑布。
你有了數據,函數鏈上的函數都是一個(gè)暗礁。數據持續的下落,可能改變了某些屬性,然后落到了下一個(gè)函數上。
最后你有一個(gè)水池了。就在這里你的數據在經(jīng)歷了許多函數后,最后落進(jìn)了水池??赡芩€會(huì )下落到下一個(gè)函數,或者你在需要的時(shí)候可以使用它。
你可以說(shuō)這就是面向過(guò)程式編程啊。但它也是函數式編程,這就是我如何理解代碼的。你的想法可能不同。
不論你是如何理解你的代碼的,不管你在你腦中如何運行代碼——但如果你能處理復雜的面向對象,我就要脫帽對你致敬。你是真的比我厲害。
我想你應該試試“函數式編程”。你會(huì )喜歡它的。
原文:swizec.com 編譯:伯樂(lè )在線(xiàn) — 唐小娟
聯(lián)系客服