簡單是Python編程的第一要則
本文是 Python 之禪特別系列的第二篇,我們將要關(guān)注其中第三與第四條原則:簡單與復(fù)雜。
Il semble que la perfection soit atteinte non quand il n'y a plus rien à ajouter, mais quand il n'y plus rien à retrancher.
It seems that perfection is finally attained not when there is no longer anything to add, but when there is no longer anything to take away.“完美并非無可增,而是不可減。”
—Antoine de Saint-Exupéry, Terre des Hommes, 1939
編程時最常有的考量是與復(fù)雜性的斗爭,只想寫出讓旁人無從下手的繁雜代碼,對每個程序員來講都算不上難事。倘若未能觸及代碼的簡繁取舍,那么 《Python 之禪》 就有了一角殘缺。
簡單勝過復(fù)雜
尚有選擇余地時,應(yīng)該選簡單的方案。Python 少有不可為之事,這意味著設(shè)計出巴洛克風(fēng)格(LCTT 譯注:即夸張和不理性)的程序只為解決淺顯的問題不僅有可能,甚至很簡單。
正因如此,編程時應(yīng)當謹記,代碼的簡單性是最易丟失,卻最難復(fù)得的。
這意味著,在可以選用函數(shù)來表達時不要去引入額外的類;避免使用強力的第三方庫往往有助于你針對迫切的問題場景設(shè)計更妥當?shù)暮喍毯瘮?shù)。不過其根本的意圖,旨在讓你減少對將來的盤算,而去著重解決手頭的問題。
以簡單和優(yōu)美作為指導(dǎo)原則的代碼相比那些想要囊括將來一切變數(shù)的,在日后要容易修改得多。
復(fù)雜勝過錯綜復(fù)雜
把握用詞的精確含義對于理解這條令人費解的原則是至關(guān)重要的。形容某事復(fù)雜,是說它由許多部分組成,著重組成成分之多;而形容某事錯綜復(fù)雜,則是指其包含著差異巨大、難以預(yù)料的行為,強調(diào)的是各組成部分之間的雜亂聯(lián)系。
解決困難問題時,往往沒有可行的簡單方案。此時,最 Python 化的策略是“自底向上”地構(gòu)建出簡單的工具,之后將其組合用以解決該問題。
這正是對象組合這類技術(shù)的閃耀之處,它避免了錯綜復(fù)雜的繼承體系,轉(zhuǎn)而由獨立的對象把一些方法調(diào)用傳遞給別的獨立對象。這些對象都能獨立地測試與部署,最終卻可以組成一體。
“自底建造” 的另一例即是單分派泛函數(shù)的使用,拋棄了錯綜復(fù)雜的對象之后,我們得到是簡單、幾乎無行為的對象以及獨立的行為。