博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ES6中的尾递归优化例子
阅读量:7260 次
发布时间:2019-06-29

本文共 1010 字,大约阅读时间需要 3 分钟。

hot3.png

1、尾递归

  • 函数调用自身,称为递归。如果尾调用自身,就称为尾递归。

2、调用帧

我们知道,函数调用会在内存形成一个“调用记录”,又称“调用帧”(call frame),保存调用位置和内部变量等信息。如果在函数A的内部调用函数B,那么在A的调用帧上方,还会形成一个B的调用帧。等到B运行结束,将结果返回到A,B的调用帧才会消失。如果函数B内部还调用函数C,那就还有一个C的调用帧,以此类推。所有的调用帧,就形成一个“调用栈”(call stack)。

递归非常耗费内存,因为需要同时保存成千上百个调用帧,很容易发生“栈溢出”错误(stack overflow)。但对于尾递归来说,由于只存在一个调用帧,所以永远不会发生“栈溢出”错误。

我们来看下面的例子:

function factorial(n) {  if (n === 1) return 1;  return n * factorial(n - 1);}

不属于尾递归,优化一下,这样就可以节省内存,不发生栈溢出

function factorial(n, total) {	if ( n === 1 ) {		return total;	}	return factorial(n - 1, n * total);}console.log( factorial(5, 1) );

下面这个也是,用到了柯里化(currying)思想,即多参数==>单参数

function Fibonacci (n) {  if ( n <= 1 ) {return 1};  return Fibonacci(n - 1) + Fibonacci(n - 2);}Fibonacci(10) // 89Fibonacci(100) // 堆栈溢出Fibonacci(500) // 堆栈溢出// 优化过后function Fibonacci(n, ac1 = 1, ac2 = 1) {	if ( n <= 1) {		return ac2;	}	return Fibonacci(n - 1, ac2, ac1 + ac2);}console.log( Fibonacci(10) );console.log( Fibonacci(1000) );

有些函数试编程的味道了

转载于:https://my.oschina.net/huangsuhong/blog/1549707

你可能感兴趣的文章
【c学习-6】
查看>>
自测题的整理(持续更新)
查看>>
DAMS2019中国数据智能管理峰会将于7月在上海召开!
查看>>
[原创]TimeQuest约束外设之诡异的Create Generated Clocks用法
查看>>
Unity UGUI —— 无限循环List(转载)
查看>>
【总结整理】《人人都是产品经理》---读后感
查看>>
第23件事 评估产品或项目是否靠谱的7个标准
查看>>
MySQL的优化与执行
查看>>
04-人员增删改查
查看>>
Python之自动单元测试之一(unittest使用实例)
查看>>
ORA-04031:oracle无法分配共享内存
查看>>
Mysql SQL Mode详解
查看>>
理解WebKit和Chromium: Chromium for Android
查看>>
Floyd算法 笔记 C/C++
查看>>
Android中再按一次退出实现
查看>>
基于Unity3D 的Vuforia SDK开发基础教程
查看>>
用户,群组和权限 二
查看>>
【转】JCR期刊分区及其检索方法
查看>>
浅思OC的语言特性
查看>>
CentOS7下用jdk1.7编译hadoop-2.7.1全过程详解
查看>>