欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript遞歸函數(shù)定義和用法示例分析

 更新時(shí)間:2020年07月22日 17:23:08   作者:雨霖月寒  
這篇文章主要介紹了javascript遞歸函數(shù)定義和用法示例分析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

遞歸函數(shù):是指函數(shù)直接或間接調(diào)用函數(shù)本身,則稱該函數(shù)為遞歸函數(shù)。

這句話理解起來(lái)并不難,從概念上出發(fā),給出以下的例子:

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

這個(gè)例子的 foo 函數(shù)就是一個(gè)遞歸函數(shù)。

當(dāng)你把這個(gè)函數(shù)拿到瀏覽器上運(yùn)行的時(shí)候,你會(huì)發(fā)現(xiàn)內(nèi)存溢出了,為什么呢?因?yàn)檫@個(gè)遞歸函數(shù)沒(méi)有停止處理或運(yùn)算的出口,因此這個(gè)遞歸函數(shù)就演變?yōu)橐粋€(gè)死循環(huán)。

那如何使用遞歸呢?

使用遞歸函數(shù)必須要符合兩個(gè)條件:

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

這句話怎么理解?

大家家里都有樓梯吧?比如從一樓走到二樓,那么我們的起點(diǎn)是一樓,目的地是二樓,當(dāng)你往上每走一個(gè)臺(tái)階是不是越接近二樓,也就是越接近目的地。
因此這句話可以這樣理解:函數(shù)每一次調(diào)用自己時(shí),就越接近于我們期望它完成的任務(wù)的終點(diǎn)。

2、必須有一個(gè)終止處理或計(jì)算的出口

這句話的意思是:必須要有一個(gè)標(biāo)準(zhǔn)的標(biāo)志,讓函數(shù)結(jié)束調(diào)用函數(shù)自身。
比如,怎么知道你已經(jīng)走到二樓了呢?當(dāng)你看到有個(gè)門(mén),門(mén)牌上寫(xiě)著 2F 的,然后推開(kāi)它跨過(guò)去,那么你就到二樓了。

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

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]); //函數(shù)調(diào)用函數(shù)自身
  }
 }
};

getObjValue(obj);

// 輸出結(jié)果:

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

使用建議:在使用遞歸時(shí),要注意對(duì)遞歸函數(shù)的參數(shù)類型的檢查,一定要保證有一個(gè)終止處理或計(jì)算的出口。否則很容易演變?yōu)樗姥h(huán),從而造成內(nèi)存溢出。

到此這篇關(guān)于javascript遞歸函數(shù)定義和用法示例分析的文章就介紹到這了,更多相關(guān)javascript遞歸函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 用JavaScript來(lái)美化HTML的select標(biāo)簽的下拉列表效果

    用JavaScript來(lái)美化HTML的select標(biāo)簽的下拉列表效果

    這篇文章主要介紹了用JavaScript來(lái)美化HTML的select標(biāo)簽的下拉列表效果的方法,而且在多瀏覽器下的兼容效果也得到提升,需要的朋友可以參考下
    2015-11-11
  • 為Javascript中的String對(duì)象添加去除左右空格的方法(示例代碼)

    為Javascript中的String對(duì)象添加去除左右空格的方法(示例代碼)

    這篇文章主要介紹了為Javascript中的String對(duì)象添加去除左右空格的方法(示例代碼)。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-11-11
  • 微信小程序?qū)崿F(xiàn)二維碼簽到考勤系統(tǒng)

    微信小程序?qū)崿F(xiàn)二維碼簽到考勤系統(tǒng)

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)二維碼簽到考勤系統(tǒng),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-01
  • 微信小程序?qū)崿F(xiàn)多圖上傳

    微信小程序?qū)崿F(xiàn)多圖上傳

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)多圖上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • JavaScript1.6數(shù)組新特性介紹以及JQuery的幾個(gè)工具方法

    JavaScript1.6數(shù)組新特性介紹以及JQuery的幾個(gè)工具方法

    這篇文章主要是對(duì)JavaScript1.6數(shù)組新特性以及JQuery的幾個(gè)工具方法進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-12-12
  • JS中for...in?和?for...of?的區(qū)別解析

    JS中for...in?和?for...of?的區(qū)別解析

    for?…?in?用于迭代對(duì)象的可枚舉字符串屬性,包括自身屬性和繼承的屬性,但不會(huì)遍歷對(duì)象的原型鏈上的?非可枚舉屬性,以及對(duì)象的方法,這篇文章主要介紹了JS中for...in?和?for...of?的區(qū)別,需要的朋友可以參考下
    2024-03-03
  • JS實(shí)現(xiàn)為排序好的字符串找出重復(fù)行的方法

    JS實(shí)現(xiàn)為排序好的字符串找出重復(fù)行的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)為排序好的字符串找出重復(fù)行的方法,涉及JavaScript字符串運(yùn)算相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2016-03-03
  • 淺談JavaScript 覆蓋原型以及更改原型

    淺談JavaScript 覆蓋原型以及更改原型

    下面小編就為大家?guī)?lái)一篇淺談JavaScript 覆蓋原型以及更改原型。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨過(guò)來(lái)看看吧
    2016-08-08
  • Javascript的字符串方法詳解

    Javascript的字符串方法詳解

    這篇文章主要介紹了Javascript字符串方法詳解的相關(guān)資料,在平時(shí)工作中經(jīng)常會(huì)用到的,非常不錯(cuò),需要的朋友可以參考下,希望能夠給你帶來(lái)幫助
    2021-09-09
  • 第四章之BootStrap表單與圖片

    第四章之BootStrap表單與圖片

    Bootstrap,來(lái)自 Twitter,是目前最受歡迎的前端框架。本文給大家介紹Bootstrap表單與圖片的相關(guān)資料,需要的朋友可以參考下
    2016-04-04

最新評(píng)論