前言
這篇文章一個多月前以英文發表在我的個人博客,現在抽空翻譯成中文,并補充一些沒來得及寫的內容。
昨天我發表的《如何在 JS 代碼中消滅 for 循環》引起很多爭議。為了避免沒營養的討論,我先聲明一下。遞歸性能差是沒爭議的事實,如果你覺得 for 循環更好,沒必要學遞歸,那看到這里你可以不用看了。這篇文章要展示的大部分代碼,僅僅是學習目的,我不推薦在生產環境中用。但是如果你對函數式編程感興趣,想深入理解一些核心概念,你應該讀下去。
今年年初我開始學 Haskell 的時候,我被函數式代碼的優雅和簡潔俘獲了。代碼居然還能這樣寫!用指令式代碼要寫一堆的程序,用遞歸幾行就解決了。這篇文章里,我會把我在 Haskell 里面看到的遞歸函數翻譯成 JS 和 Python,并盡量每一步解釋。最后我會嘗試解決遞歸爆棧(Stack Overflow)的問題。
遞歸基礎
我從 Python 代碼開始,然后展示 JS 實現。
很多解釋遞歸的教程是從解釋斐波那契數列開始的,我覺得這樣做是在用一個已經復雜的概念去解釋另一個復雜的概念,沒有必要。我們還是從簡單的代碼開始吧。
運行這段 Python 代碼:
def foo(): foo()foo()
當然會報錯。
注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
新聞熱點
疑難解答