本文实例分析了JavaScript递归操作。分享给大家供大家参考,具体如下:
问题
一个简单的递归,求n的阶乘:
function factorial(n){ if (n<=1) { return 1; }else{ return factorial(n-1)*n; } }
如果像下面这样使用它,则会出错:
var fcopy = factorial; factorial = null; alert(fcopy(3));
因为fcopy指向的函数实体调用了factorial,而factorial已经被释放。
解决的办法
使用arguments.callee
执行流进入函数时会创建函数的运行环境(作用域链等),包括 arguments 这个特殊对象,arguments对象有个属性指向函数本身:arguments.callee 。
function factorial(n){ if (n<=1) { return 1; }else{ return arguments.callee(n-1)*n; } }
不过callee在严格模式下不可用。
使用函数表达式
var factorial = (function f(n){ if (n<=1) { return 1; }else{ return f(n-1)*n; } })
这并非使用了什么新的技术,只是在原来概念上的一种应用,在定义 factorial 时,直接创建一个函数,再将此函数的引用赋值给factorial。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript遍历算法与技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
JavaScript,递归操作
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。