返回顶部
首页 > 资讯 > 前端开发 > VUE >javascript中有哪些栈
  • 520
分享到

javascript中有哪些栈

2024-04-02 19:04:59 520人浏览 薄情痞子
摘要

这篇文章主要讲解了“javascript中有哪些栈”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript中有哪些栈”吧!

这篇文章主要讲解了“javascript中有哪些栈”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript中有哪些栈”吧!

javascript中没有栈,可以使用数组实现栈的所有功能;栈是一种后进先出的数据结构,似乎一种特殊的列表,任何不在栈顶的元素都无法访问,需要先拿掉上面的元素,才能得到栈底的元素,例如可以利用push()将元素添加到栈顶。

教程操作环境:windows10系统、javascript1.8.5版、Dell G3电脑。

javascript中有几个栈

JavaScript中没有栈,但是可以用数组实现栈的所有功能。

栈是一种线性结构,最大的特点就是先进后出,后进先出。

javascript中有哪些栈

入栈push():

javascript中有哪些栈

出栈pop():

javascript中有哪些栈

栈:

栈是一种和列表类似的数据结构,可以用它来解决很多的编程问题,栈是一种高效的数据结构,因为数据只能在栈的顶端添加或者删除,所以这样的操作很快而且容易实现。

  栈是一种特殊的列表,站内的元素只能拖过列表的一端进行访问,这一端陈伟栈顶。一叠盘子是最常见的栈结构,只能从顶部取盘子,洗好的盘子也只能放在顶端。栈被称为后入先出的数据结构。

  由于栈具有后入先出的特点,所以任何不在栈顶的元素都无法访问。为了得到栈底的元素,必须拿掉上面的元素。

  对栈的操作有将一个元素压入栈和将一个元素弹出栈。把元素压入栈顶使用push()方法,从栈顶弹出元素使用pop()方法。还有一个方法是预览栈顶元素,使用pop()方法虽然可以访问栈顶的元素,但是调用该方法后栈顶的元素将被永久的删除。peek()方法只返回栈顶的元素,而不删除它。

  为了记录栈顶元素的位置,同时也为了标记从哪里可以加入新元素,我们使用变量top,当向栈内压入元素是该变量增大,从站内弹出元素时,该变量减小。

  pop(),push(),peek()方法是最主要的三个方法,同时定义clear()方法可以清楚栈内所有的元素,length属性定义栈内元素的个数,同时定义一个empty属性标识栈内是否还有元素,不过使用length属性可以达到同样的目的。

定义栈的操作

  栈作为一种特殊的列表,只能从一端来进行访问,就像一摞盘子,放只能放在上面,拿也只能从上面拿,所以栈是一种先入后出的一种数据结构。因为栈的这种特点,栈中任意不在栈顶的元素都无法访问,为了得到栈底的元素,必须把该元素之上的元素拿掉,把栈底的元素暴露在栈顶。栈还可以清空其内所有元素,也可以记录栈内元素的个数。

  综上,我们定义几个操作栈的方法。

  • push()    把元素添加到栈顶

  • pop()     把元素从栈顶删除

  • peek()    返回栈顶的元素

  • clear()    清空栈内元素

  • length()    栈内元素的个数

栈的实现

  实现栈,底层的数据结构采用数组,以定义栈的构造函数开始;

function Stack() {
    this.dataStore = [];         //用来保存栈内元素的数组
    this.top = 0;                   //top用来记录栈顶位置,初始化为0
    this.push = push;
    this.pop = pop;
    this.peek = peek;
    this.clear = clear;
    this.length = length;
}

  接下来实现push(),pop(),peek(),clear()和length()。

push()方法是,当向栈顶添加一个新元素时,在数组的记录栈顶的位置的top的位置添加这个值,添加完成top需要加1;

pop()正好与push()相反,需要top减1,但同时减1之后返回top位置的值,即已删除元素;

peek()直接返回数组top-1位置的元素,即栈顶元素就可以了;

clear() 直接把top值赋为0,直接清空栈;

length()直接返回top的值,栈顶位置即栈内元素个数

function push(element) {
    this.dataStore[this.top++] = element;   // 先在top位置加入元素,之后top加1
}
function pop() {
    return this.dataStore[--this.top];   // top先减1,然后返回top位置的元素
}
function peek() {
    return this.dataStore[this.top - 1];
}
function clear() {
    this.top = 0;
}
function length() {
    return this.top;
}

感谢各位的阅读,以上就是“javascript中有哪些栈”的内容了,经过本文的学习后,相信大家对javascript中有哪些栈这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: javascript中有哪些栈

本文链接: https://lsjlt.com/news/98251.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • javascript中有哪些栈
    这篇文章主要讲解了“javascript中有哪些栈”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript中有哪些栈”吧! ...
    99+
    2024-04-02
  • JavaScript中栈和堆的区别有哪些
    本篇内容主要讲解“JavaScript中栈和堆的区别有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中栈和堆的区别有哪些”吧! ...
    99+
    2024-04-02
  • JavaScript错误和调用栈常识都有哪些
    JavaScript错误和调用栈常识都有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。大多数工程师可能并没留意过 JS 中错误对象、错误堆...
    99+
    2024-04-02
  • web技术栈中的池有哪些
    本篇内容主要讲解“web技术栈中的池有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web技术栈中的池有哪些”吧!连接池相信每一个程序员都不陌生,我们在使用...
    99+
    2024-04-02
  • Python全栈中JS的知识有哪些
    小编今天带大家了解Python全栈中JS的知识有哪些,文中知识点介绍的非常详细。觉得有帮助的朋友可以跟着小编一起浏览文章的内容,希望能够帮助更多想解决这个问题的朋友找到问题的答案,下面跟着小编一起深入学习“Python全栈中JS的知识有哪些...
    99+
    2023-06-28
  • golang中堆与栈的区别有哪些
    本篇内容介绍了“golang中堆与栈的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!堆与栈的区别:1、堆是用于存放进程执行中被动态...
    99+
    2023-07-05
  • javascript中有哪些框架
    这篇文章给大家介绍javascript中有哪些框架,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 javascript主要框架:Angular、React、...
    99+
    2024-04-02
  • javascript中有哪些类型
    这篇“javascript中有哪些类型”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“jav...
    99+
    2024-04-02
  • javascript中的库有哪些
    本篇内容主要讲解“javascript中的库有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript中的库有哪些”吧!JavaScript 库J...
    99+
    2024-04-02
  • javascript中有哪些循环
    javascript中的循环有:1.for循环,先判断后循环;2.while循环,先判断后循环;3.do while循环,先循环后判断;javascript中的常用的循环有以下几种for循环javascript中for循环是一种先判断后循环...
    99+
    2024-04-02
  • javascript中有哪些作用
    这篇文章主要介绍了javascript中有哪些作用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript有什么特点1、js属于一种解释性脚本语言;2、在绝大多数浏...
    99+
    2023-06-15
  • javascript中对象有哪些
    这篇文章将为大家详细讲解有关javascript中对象有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。JavaScript有什么特点1、js属于一种解释性脚本语言;2、在绝大多数浏览器的...
    99+
    2023-06-14
  • Java栈的知识点有哪些
    这篇文章主要介绍了Java栈的知识点有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java栈的知识点有哪些文章都会有所收获,下面我们一起来看看吧。1.栈的概念栈(stack)又名堆栈,作为一种数据结构,是...
    99+
    2023-06-29
  • java 堆和栈的区别有哪些
    Java中存在栈这样一个后进先出(Last In First Out)的顺序的数据结构,这就是java.util.Stack。这种情况下,不免让很多人更加费解前面的问题。事实上,堆和栈都是内存中的一部分,有着不同的作用,而且一个程序需要在这...
    99+
    2019-11-24
    java入门 java 区别
  • Python全栈的运算符有哪些
    本篇内容主要讲解“Python全栈的运算符有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python全栈的运算符有哪些”吧!1. 算数_比较_赋值_成员1.1 算数运算符算数运算符: + ...
    99+
    2023-06-21
  • java常见的栈溢出有哪些
    在Java中,常见的栈溢出错误有以下几种:1. 递归调用造成的栈溢出:当一个方法递归调用自身次数过多,导致栈空间被耗尽,就会发生栈溢...
    99+
    2023-08-31
    java
  • javascript中UMD规范有哪些
    本篇文章为大家展示了javascript中UMD规范有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. UMD规范UMD规范,就是所有规范里长得最丑的那个,没...
    99+
    2024-04-02
  • JavaScript中有哪些缓存API
    JavaScript中有哪些缓存API,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。检测Cache支持检查 caches 对象在 wind...
    99+
    2024-04-02
  • javascript中有哪些dom事件
    这篇文章主要介绍“javascript中有哪些dom事件”,在日常操作中,相信很多人在javascript中有哪些dom事件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ja...
    99+
    2024-04-02
  • javascript中有哪些微任务
    本篇内容主要讲解“javascript中有哪些微任务”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript中有哪些微任务”吧! ...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作