你真的了解“栈”吗?_栈读音是什么意思

2023-03-31 08:22:37

 

1.栈什么字怎么读

堆栈(stack)又称为栈或堆叠,是计算机科学里最重要且最基础的数据结构之一,它按照FILO(First In Last Out,后进先出)的原则存储数据栈一种遵从先进后出 (LIFO) 原则的有序集合;新添加的或待删除的元素都保存在栈的末尾,称作栈顶,另一端为栈底。

2.栈念什么字

在栈里,新元素都靠近栈顶,旧元素都接近栈底栈的定义:栈是一个数据集合,可以理解为只能在一端进行插入或删除操作的列表栈的特点:后进先出(last-in,first-out), 简称LIFO表类似一摞书:

3.栈怎么读拼音是什么

image.png栈的概念:栈顶:允许插入和删除的这一端称为栈顶栈底:另外固定的这一端称为栈底空栈:不含任何元素的栈称为空栈栈的基本操作:压栈:push出栈:pop取栈顶:gettop(查看栈顶元素,但不取走) li[-1]。

4.栈是什么意思啊

image.png栈的JS实现

5.栈这是什么字

JS的调用栈执行上下文:就是当前JS代码被解析和执行所在环境的抽象的概念JS中的任何代码都是在执行上下文中运行的。(执行环境)

6.栈这个字的拼音是什么

JS引擎创建一个新的全局执行上下文并且将这个执行上下文推入到当前的执行栈中执行栈用于:存储在代码执行期间创建的所有的执行上下文每当发生函数调用的时候,JS引擎都会为该函数创建一个新的执行上下文并且PUSH到当前执行栈的栈顶

7.栈怎么念?

当调用one函数的时候,js引擎为这个函数创建一个新的执行上下文并将其推到当前执行栈的栈顶当调用two函数的时候,js引擎为这个函数创建一个新的执行上下文并将其推到当前执行栈的栈顶当two函数调用完毕以后,它的执行上下文从

8.栈这个怎么读

当前执行栈中弹出上下文的控制权移到当前执行栈中的下一个执行上下文递归与栈函数的调用的本质:“压栈与出栈操作”函数在在调用栈里边有一个特例,叫做递归递归:自己调自己递归调用,递归栈LIFO先进栈,到条件后再出栈,如果不出栈,就会导致:栈溢出。

9.栈怎么读拼音是什么字

阶乘

10.这个字栈念什么

尾调用优化尾调用(Tail Call)是函数式编程的一个重要概念,本身非常简单,一句话就能说清楚,就是指某个函数的最后一步是调用另一个函数function f(x){ return g(x); } 在开始进一步了解尾调用优化前,我们首先要熟悉两个概念,分别是调用栈(call stack)和调用帧(call frame)。

调用栈(call stack)调用栈是一种栈结构的数据,它是由调用侦组成的调用栈记录了函数的执行顺序和函数内部变量等信息程序运行到一个函数,它就会将其添加到“调用栈”中,当从这个函数返回的时候,就会将这个函数从调用栈中删掉。

调用帧(call frame)每个进入到调用栈中的函数,都会分配到一个单独的栈空间,称为“调用侦”在调用栈中每个“调用侦”都对应一个函数,最上方的调用帧称为“当前帧”,调用栈是由所有的调用侦形成的

image.png尾调用之所以与其他调用不同,就在于它的特殊的调用位置如果在函数A的内部调用函数B,那么在A的调用帧上方,还会形成一个B的调用帧等到B运行结束,将结果返回到A,B的调用帧才会消失如果函数B内部还调用函数C,那就还有一个C的调用帧,以此类推。

所有的调用帧,就形成一个“调用栈(call stack)”。话不多说,举个例子

调用栈情况参考下图:

image.png造成这种结果是因为每个函数在调用另一个函数的时候,并没有 return 该调用,所以JS引擎会认为你还没有执行完,会保留你的调用帧three() 里面调用了 two() 函数,并没有 。

return 该调用,所以在调用栈中保持自己的调用帧,同时 two() 函数的调用帧在调用栈中生成,同理,two() 函数又调用了 one() 函数,最后执行到 one() 函数的时候,没有再调用其他函数,这里没有显示声明

return,所以这里默认 return undefinedone() 执行完了,销毁调用栈中自己的记录,依次销毁 two() 和 three() 的调用帧,最后完成整个流程如果对上面的例子做如下修改:。

如果尾调用优化生效,流程图就会变成这样:

image.png我们可以很清楚的看到,尾调用由于是函数的最后一步操作,所以不需要保留外层函数的调用记录,只要直接用内层函数的调用记录取代外层函数的调用记录就可以了,调用栈中始终只保持了一条调用帧这就叫做。

尾调用优化(Tail call optimization),即只保留内层函数的调用帧如果所有的函数都是尾调用的话,调用位置、内部变量等信息都不会再用到了,那么在调用栈中的调用帧始终只有一条,这样会节省很大一部分的内存,这也是。

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

上面代码是一个阶乘函数,计算n的阶乘,最多需要保存n个调用记录,空间复杂度 O(n) 。如果改写成尾递归,只保留一个调用记录,空间复杂度 O(1) 。

还有一个比较著名的例子,就是计算 Fibonacci 数列,也能充分说明尾递归优化的重要性。非尾递归的 Fibonacci 数列实现如下。

尾递归优化过的 Fibonacci 数列实现如下。

由此可见,“尾调用优化”对递归操作意义重大,所以一些函数式编程语言将其写入了语言规格ES6 亦是如此,第一次明确规定,所有 ECMAScript 的实现,都必须部署“尾调用优化”朵拉姐【ITI2018】的前端摸鱼技术群。

欢迎大家技术交流 内推 摸鱼 求助皆可 - 链接系列链接(后续都会更新完毕)前端一姐:数据结构--队列前端一姐:JS数组不是“真”的数组?前端一姐:终于理解希尔排序与插入排序前端一姐:一图读懂快速排序(Quick Sort)

前端一姐:一图读懂插入排序(Insertion Sort)前端一姐:冒泡排序与选择排序的区别

 


以上就是关于《你真的了解“栈”吗?_栈读音是什么意思》的全部内容,本文网址:https://www.7ca.cn/baike/10061.shtml,如对您有帮助可以分享给好友,谢谢。
声明

排行榜