JavaScript中的函數(shù)調(diào)用自身,又稱為遞歸。遞歸是一種強大的技術,允許我們以一種優(yōu)雅而簡單的方式來解決某些問題。遞歸函數(shù)是在執(zhí)行過程中調(diào)用自身的函數(shù)。這樣做通常涉及到一個或多個基準情況或條件,用于控制函數(shù)何時停止調(diào)用自身。
下面是一個簡單的遞歸函數(shù)示例:
function factorial(num){ if(num === 1){ return 1; } else { return num * factorial(num - 1); } }
這個函數(shù)的作用是計算一個整數(shù)的階乘。該函數(shù)首先檢查傳遞的參數(shù)是否等于1。如果是,則返回1作為結果,否則,它將遞歸調(diào)用自身,并傳入一個小于原始參數(shù)num的數(shù)字。該函數(shù)將繼續(xù)遞歸調(diào)用自身,直到達到基準情況(num === 1),然后返回1,從而停止遞歸。
下面是一個更復雜的示例,用于生成一個數(shù)字范圍內(nèi)所有整數(shù)的數(shù)組:
function createRange(startNum, endNum) { var arr = []; function range(start, end){ if (start === end) { arr.push(end); return; } else if (start< end) { arr.push(start); range(start + 1, end); } else { arr.push(start); range(start - 1, end); } } range(startNum, endNum); return arr; }
該函數(shù)調(diào)用自身來生成指定范圍內(nèi)的所有整數(shù)的數(shù)組。range函數(shù)檢查開始數(shù)是否等于結束數(shù),如果是,則將結束數(shù)添加到數(shù)組中,并返回。如果開始數(shù)小于結束數(shù),它將開始數(shù)添加到數(shù)組中,然后遞歸調(diào)用自身并傳入`start + 1`和`end`。如果開始數(shù)大于結束數(shù),它將開始數(shù)添加到數(shù)組中,然后遞歸調(diào)用自身并傳入`start - 1`和`end`。遞歸將繼續(xù)進行直到`start === end`,然后退出。
遞歸函數(shù)可以使用到一些高級的技巧,如尾遞歸優(yōu)化,但也需要注意避免遞歸過深造成調(diào)用棧溢出的風險。在實際開發(fā)中,遞歸函數(shù)應該使用得恰到好處,不斷練習和研究才能得到更好的運用。