javascript --- 遞歸的簡單理解

来源:http://www.cnblogs.com/beyond-succeed/archive/2016/09/02/5832213.html
-Advertisement-
Play Games

遞歸函數大家都應該比較熟吧?那麼,如何在JavaScript中書寫一個完美的遞歸函數呢?且聽我娓娓道來。 遞歸函數 寫的時候,查了一下維基百科對遞歸函數的定義,恕我愚鈍,簡直太深奧了!所以,我還是簡單的說說我對遞歸函數的理解吧。遞歸函數,說白了就是在函數內部引用函數自身,最終到給定的遞歸結束條件時回 ...


歸函數大家都應該比較熟吧?那麼,如何在JavaScript中書寫一個完美的遞歸函數呢?且聽我娓娓道來。

遞歸函數


寫的時候,查了一下維基百科對遞歸函數的定義,恕我愚鈍,簡直太深奧了!所以,我還是簡單的說說我對遞歸函數的理解吧。遞歸函數,說白了就是在函數內部引用函數自身,最終到給定的遞歸結束條件時回溯。當然,你也可以不給定結束條件,死了別掛我~(╯﹏╰)~。

簡單說就是有兩個條件:

  1. 在函數內部引用自身。

  2. 每個遞歸函數里必定有一個終止條件。

來個小李子:

function test(num){
    if(num <= 1){
        return 1;
    }else{
        return num * test(num-1);
    }
}
var a = test;
console.log(a(6)); // 1

 好了,不錯,一個堪稱經典的遞歸求階乘的函數誕生了。事情肯定不會這麼順利,一定是個圈套。我們來如下調用以下看看會怎麼樣?

var a = test;
test = null;
console.log(a(6)); // Uncaught TypeError: test is not a function

居然報錯了

回過頭去看看我們是如何調用的。發現問題了吧!我們把test賦給了a,然後把test給回收掉了。為什麼會出錯呢?因為像function這種賦值其實是引用傳遞,只是把指向函數的指針(這裡說地址也行)賦給a了。但我們把test賦值為null的時候,函數都已經被回收了,拿什麼來執行?知道問題所在了,我決定換種方式來定義:

function test(num){
    if(num <= 1){
        return 1;
    }else{
        return num * arguments.callee(--num); 
    }
}

然後測試一下:

var test = fun;
fun = null;
console.log(test(7));

用arguments.callee可解決問題,這是一個指向正在執行的函數的指針,arguments.callee返回正在被執行的對現象。 

但是在某一天,當我實際碼代碼的時候,問題又出現了。什麼問題呢?我們來看一下:

Uncaught TypeError: 'caller', 'callee', and 'arguments' properties may not be accessed on strict mode functions or the arguments objects for calls to them 

╮(╯▽╰)╭哎!可憐啊!因為我使用了"use strict"!嚴格模式下是不允許的。。。

好吧!繼續想辦法!既然不能使用arguments.callee(),那還是想想其他的方式吧。

var fun = (function f(num){
    if(num <= 1){
        return 1;
    } else{
        return num * f(--num); 
    }
});

然後我測試了以下,神奇的通過了,暫時沒有發現任何問題!

為什麼呢?因為我們使用了“()”,巧妙地使用命名函數表達式來達到了同樣的效果。

<( ̄︶ ̄)><( ̄︶ ̄)><( ̄︶ ̄)><( ̄︶ ̄)><( ̄︶ ̄)><( ̄︶ ̄)><( ̄︶ ̄)>


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文為原創文章,轉載請註明出處,謝謝 分散式鎖 1、原理 建立表示鎖的父節點(圖中locker節點) 每個爭搶鎖的伺服器在locker節點下創建有序的臨時節點 判斷自己是否搶到鎖:獲取locker下所有子節點,併進行從小到大排序,判斷自己創建的臨時節點是否是最小節點。 是最小節點,說明搶到鎖,執行相 ...
  • 顯示上面照片效果css ...
  • [1]getBoundingClientRect [2]getClientRects [3]elementFromPoint ...
  • 閑來無事,自己搞了一個圖片輪播的jQuery插件,話不多說,直接上代碼咯!!!!! 1、HTML模塊的代碼很簡單。寫一個容器就可以了,之後往裡面加入圖片輪播的效果 <div class="index-banner" id="banner"></div> 2、樣式代碼 1 .index-banner ...
  • 1 function ajax() 2 { 3 var xmlHttp=null; 4 if(windows.XMLHttpRequest){ 5 xmlHttp=new XMLHttpRequest(); 6 } 7 else{ 8 if(windows.ActiveXObject){ 9 xml ...
  • 一把心酸一把淚。。。 這兩年一直在做智能交通的技術支持,現在想換行業,把簡歷貼出去只有技術支持崗位的公司來電話。自學了一個月,如果沒有進入開發項目的話,感覺好難成長起來;比如說現在就很迷茫。不清楚前端的路是怎麼走的,閉門造車。就怕學了一堆,然後別人說,你學的東西沒人在用了。 昨天,跟領導說換到研發部 ...
  • 閉包 就是指一個有權訪問另外一個函數作用域中的變數的函數。 《JavaScript高級程式第三版》 本人對於閉包初次的認識就來自《高三》,首先僅僅通過 “有權”’ 兩個字我們便可以進一步推斷出。在正常情況下,一個函數是 “無權” 訪問另外一個函數的作用域中的變數。 一、什麼是變數 因此在淺談 閉包 ...
  • ng-grid是基於AngularJS和JQuery的富表格控制項,由AngularUI Team領銜開發,到目前為止已有2354次Commit,1076個Fork。 AngualrUI:http://angular-ui.github.io/ ng-grid: http://angular-ui.g ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...