广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >JavaScript中的闭包
  • 853
分享到

JavaScript中的闭包

javascript前端java 2023-08-18 15:08:12 853人浏览 泡泡鱼
摘要

一.什么是闭包 1.闭包的定义 闭包并不是js特有的,因此可以从两个角度定义闭包。 1)计算机科学中 闭包又称为词法闭包(在进行词法分析的时候这个闭包就确定了),或者是函数闭包。是在支持头等函数的编程语言中(意思是函数作为一等公民的编程语言

一.什么是闭包

1.闭包的定义

闭包并不是js特有的,因此可以从两个角度定义闭包。

1)计算机科学中
  • 闭包又称为词法闭包(在进行词法分析的时候这个闭包就确定了),或者是函数闭包。
  • 是在支持头等函数的编程语言中(意思是函数作为一等公民的编程语言中),实现词法绑定的一种技术。
  • 闭包在实现上是一个结构体,它存储了一个函数和一个关联的环境,相当于一个符号查找表。
  • 闭包跟函数最大的区别在于,当捕捉闭包的时候,它的自由变量会在捕捉时被确定,这样即使脱离了捕捉时的上下文,它也能照常运行。
2)javascript
  • 一个函数和对其周围状态(lexical environment,词法环境)的引用捆绑在一起(或者说函数被引用包围),这样的组合就是闭包。
  • 也就是说,闭包让你可以在一个内层函数中访问到其外层函数的作用域。
  • 在JavaScript中,每当创建一个函数,闭包就会在函数创建的同时被创建出来。

2.图解闭包的含义

  1. 在全局代码执行前先创建Go,然后创建全局执行上下文,在全局执行上下文准备执行代码的时候,会对代码提前编译,变量会被定义,但是都还没有被赋值,是undefined,这个时候发现其中定义的有foo函数,需要对它进行解析,再在堆内存中创建一个函数对象。
    在这里插入图片描述
    在这里插入图片描述
    这个函数对象中其实是包括父级作用域和函数执行体的。
    在这里插入图片描述
    它的上层作用域是GO,那么会指向GO,指针之间会存在一个相互指向。
    在这里插入图片描述
  2. 在全局执行上下文中会有一个VO,它是指向GO的,下面是开始执行代码。开始执行代码的时候,就调用了这个foo函数,这个时候会在调用栈中创建一个函数执行上下文(FEC),函数执行之前要先创建AO对象,在对函数中的代码提前编译的时候发现其中有一个函数,就会先创建一个bar函数对象。
    在这里插入图片描述
  3. 然后开始执行代码
    那么在执行代码给fn赋值的时候,foo函数返回的是bar这个函数,这个bar在AO对象中其实保存的是这个函数的引用,0xb00,那么这个给fn赋值的其实就是0xb00。
    在这里插入图片描述
    4)执行完之后就会对foo这个函数上下文进行删除操作,接着执行fn()这个代码,接着找到了0xb00这个函数对象,因此会接着创建一个bar函数执行上下文,然后在bar函数中执行了打印的操作。
    在这里插入图片描述
  4. 这个操作执行完毕之后,这个bar的函数上下文也就不存在了。然后这些步骤完成之后,GO对象没有被销毁,但是属于foo函数、bar函数的AO对象其实是会被销毁的,因为没有引用指向它了。
    6)现在对这个代码做一些改变
    在这里插入图片描述
    与上面一段代码只有一点点不一样,就是在执行foo函数的时候,在形成AO的时候多了一个变量name,那么在函数执行上下文中开始执行代码的时候,是下面这样的过程。
    在这里插入图片描述
    然后执行到最后return bar,其实就是return 0xb00,返回之后foo函数就已经执行完毕了。在执行完第9行代码之后内存中的应当是下面这个过程。
    在这里插入图片描述
    然后执行第10行代码,再创建bar函数的执行上下文,然后执行代码,这里bar函数中引用了一个变量name,在执行上下文中当使用变量的时候,会沿着作用域链去查找。
    在这里插入图片描述
    最终打印的结果应该是 bar foo,这就形成了严格的闭包。
    在正常情况下,foo执行完毕之后,其中的AO对象应该被销毁,但是在执行这个bar函数的时候,发现仍然能够使用foo的AO对象中的name,仍然能够被访问到,这个场景中闭包就是bar函数本身+bar中能够访问到外层的自由变量name。也就是闭包包括两部分:函数+它可以访问的自由变量,这个自由变量其实就是上层作用域中使用的某些变量,其实外层作用域的变量都可以使用的,我们使用了的上层作用域中的变量就叫做自由变量。
    那么其实可以说下面这种情况也是闭包。
    在这里插入图片描述
    这个demo的外层作用域其实就是全局变量。

3.对于闭包含义的一些争议

如果在外层定义了一个变量,在内层函数中没有使用(也就是上图中没有打印name,没有使用name),这种情况下是否称为闭包?

  • 一个普通的函数function,如果它可以访问外层作用域的自由变量,那么这个函数就是一个闭包。
  • 从广义的角度上,JavaScript中的函数都是闭包。
  • 从狭义的角度上,JavaScript中一个函数,如果确实是访问了外层作用域的变量,那么它是一个闭包,见上图那种情况。

来源地址:https://blog.csdn.net/qq_44482048/article/details/128714553

--结束END--

本文标题: JavaScript中的闭包

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中的闭包
    一.什么是闭包 1.闭包的定义 闭包并不是JS特有的,因此可以从两个角度定义闭包。 1)计算机科学中 闭包又称为词法闭包(在进行词法分析的时候这个闭包就确定了),或者是函数闭包。是在支持头等函数的编程语言中(意思是函数作为一等公民的编程语言...
    99+
    2023-08-18
    javascript 前端 java
  • JavaScript中闭包的使用
    本篇内容介绍了“JavaScript中闭包的使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!通过深入了解...
    99+
    2022-10-19
  • JavaScript中的闭包是怎样的
    这篇文章给大家介绍JavaScript中的闭包是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. 闭包的概念来看一般函数的执行和启发:function stop() {  ...
    99+
    2023-06-22
  • JavaScript中闭包怎么用
    这篇文章将为大家详细讲解有关JavaScript中闭包怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。闭包真的是学过一遍又一遍,Js博大精深,每次学习都感觉有新的收获...
    99+
    2022-10-19
  • JavaScript中什么是闭包
    这篇文章给大家介绍JavaScript中什么是闭包,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 一 、词法定义域 LexicalClosure闭包是编程语言Lexical ...
    99+
    2022-10-19
  • Javascript中的闭包有什么用
    这篇文章给大家介绍Javascript中的闭包有什么用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。var array = []; array.lengt...
    99+
    2022-10-19
  • javascript中什么指的是闭包
    这篇文章主要为大家展示了“javascript中什么指的是闭包”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“javascript中什么指的是闭包”这篇文章吧。 ...
    99+
    2022-10-19
  • JavaScript中闭包的简单应用
    这篇文章主要讲解了“JavaScript中闭包的简单应用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript中闭包的简单应用”吧!闭包定义在J...
    99+
    2022-10-19
  • JavaScript 中的作用域与闭包
    目录一、JavaScript 是一门编译语言1.1 传统编译语言的编译步骤1.2 JavaScript 与传统编译语言的区别二、作用域(Scope)2.1 LHS查询 和 RHS查询...
    99+
    2022-11-13
  • 一文详解JavaScript中的闭包
    JavaScript 闭包是一种重要的概念,在 JavaScript 编程中被广泛使用。尽管它可能会让初学者感到困惑,但它是理解 JavaScript 语言核心的关键概念之一。本文将深入探讨 JavaScript 闭包,让你了解它是如何工作...
    99+
    2023-05-14
    闭包 前端 JavaScript
  • 分享JavaScript闭包
    本篇内容主要讲解“分享JavaScript闭包”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“分享JavaScript闭包”吧!  1. 概述  闭包(clos...
    99+
    2022-10-19
  • JavaScript闭包详解
    目录1.什么是闭包?1.2 闭包的记忆性:函数能够记住定义时所处的环境1.3 闭包现象:JS中每次创建函数时都会创建闭包2.闭包的功能:记忆性、模拟私有变量2.1 记忆性2.2 模拟...
    99+
    2022-11-12
  • JavaScript中怎么应用闭包
    JavaScript中怎么应用闭包,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。什么是闭包(Closure)简单讲,闭包就是指有权访问另一...
    99+
    2022-10-19
  • Javascript中如何实现闭包
    这篇文章主要介绍了Javascript中如何实现闭包,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。闭包(closure)是Javascrip...
    99+
    2022-10-19
  • JavaScript中闭包有什么用
    这篇文章主要介绍JavaScript中闭包有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1. 什么是闭包闭包:函数本身和该函数声明时所处的环境状态的组合。也就是说函数不在其定义的环境中被调用,也能访问定义时所...
    99+
    2023-06-25
  • Javascript中的闭包知识点讲解
    本篇内容介绍了“Javascript中的闭包知识点讲解”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. ...
    99+
    2022-10-19
  • javascript中闭包closure的代码案例
    这篇文章主要讲解了“javascript中闭包closure的代码案例”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript中闭包closure的代码案例”吧!简介闭包closu...
    99+
    2023-06-06
  • JavaScript中闭包的作用有哪些
    JavaScript中闭包的作用有哪些?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。JavaScript是什么JavaScript是一种直译式的脚本语言,其解释...
    99+
    2023-06-14
  • JavaScript中的闭包closure怎么使用
    这篇文章主要介绍“JavaScript中的闭包closure怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript中的闭包closure怎么使用”文章能帮助大家解决问题。闭包简述...
    99+
    2023-07-02
  • JavaScript闭包closure详述
    目录一、什么是闭包二、闭包的作用前言: 在JavaScript部分,闭包是很重要的东西,所以我们今天就闭包的相关知识做一总结。首先,在了解闭包前,我们先要知道作用域的相关知识,前面 ...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作