国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

javascript遞歸函數定義和用法示例分析

瀏覽:2日期:2023-10-20 15:52:23

遞歸函數:是指函數直接或間接調用函數本身,則稱該函數為遞歸函數。

這句話理解起來并不難,從概念上出發,給出以下的例子:

function foo(){ console.log('函數 foo 是遞歸函數。'); foo();}

這個例子的 foo 函數就是一個遞歸函數。

當你把這個函數拿到瀏覽器上運行的時候,你會發現內存溢出了,為什么呢?因為這個遞歸函數沒有停止處理或運算的出口,因此這個遞歸函數就演變為一個死循環。

那如何使用遞歸呢?

使用遞歸函數必須要符合兩個條件:

1、 在每一次調用自己時,必須是(在某種意義上)更接近于解;

這句話怎么理解?

大家家里都有樓梯吧?比如從一樓走到二樓,那么我們的起點是一樓,目的地是二樓,當你往上每走一個臺階是不是越接近二樓,也就是越接近目的地。因此這句話可以這樣理解:函數每一次調用自己時,就越接近于我們期望它完成的任務的終點。

2、必須有一個終止處理或計算的出口

這句話的意思是:必須要有一個標準的標志,讓函數結束調用函數自身。比如,怎么知道你已經走到二樓了呢?當你看到有個門,門牌上寫著 2F 的,然后推開它跨過去,那么你就到二樓了。

用遞歸輸出對象里包含的所有屬性值(包括對象里的子孫對象):

var obj = { a:{ name:'john', age:26, sex:'male', child:{ firstChild:'mak', laseChild:'loy' } }, b:{ name:'joe', age:28, sex:'female', child:{ firstChild:'bill', secondChild:'ruth', laseChild:'yoki' } }};function getObjValue(obj){ for(var k in obj){ if(typeof obj[k] !== 'object'){ console.log(obj[k]); //遞歸出口 }else{ getObjValue(obj[k]); //函數調用函數自身 } }};getObjValue(obj);

// 輸出結果:

// name=john// age=26// sex=male// firstChild=mak// laseChild=loy// name=joe// age=28// sex=female// firstChild=bill// secondChild=ruth// laseChild=yoki

使用建議:在使用遞歸時,要注意對遞歸函數的參數類型的檢查,一定要保證有一個終止處理或計算的出口。否則很容易演變為死循環,從而造成內存溢出。

到此這篇關于javascript遞歸函數定義和用法示例分析的文章就介紹到這了,更多相關javascript遞歸函數內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 翁牛特旗| 浦北县| 应城市| 颍上县| 澄城县| 盱眙县| 浠水县| 青田县| 会宁县| 上虞市| 剑阁县| 广丰县| 明星| 肥城市| 昌黎县| 龙岩市| 利津县| 屯昌县| 鄂温| 亚东县| 富阳市| 左权县| 南开区| 浦北县| 焦作市| 柳河县| 东丽区| 遂平县| 青浦区| 平罗县| 嘉兴市| 仁化县| 阿荣旗| 社旗县| 贵德县| 五寨县| 时尚| 余庆县| 岢岚县| 青铜峡市| 兰西县|