位置: 编程技术 - 正文

理解javascript函数式编程中的闭包(closure)(javascript的理解)

编辑:rootadmin

推荐整理分享理解javascript函数式编程中的闭包(closure)(javascript的理解),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript的function,javascript函数如何定义及其作用,javascript的function,js函数怎么理解,javascript函数如何定义及其作用,javascript的function,javascript的理解,javascript中的函数如何理解,内容如对您有帮助,希望把文章链接给更多的朋友!

闭包(closure)是函数式编程中的概念,出现于 世纪 年代,最早实现闭包的语言是 Scheme,它是 LISP 的一种方言。之后闭包特性被其他语言广泛吸纳。 闭包的严格定义是“由函数(环境)及其封闭的自由变量组成的集合体。”这个定义对于大家来说有些晦涩难懂,所以让我们先通过例子和不那么严格的解释来说明什么是闭包,然后再举例说明一些闭包的经典用途。

什么是闭包

通俗地讲, JavaScript 中每个的函数都是一个闭包,但通常意义上嵌套的函数更能够体 现出闭包的特性,请看下面这个例子:

理解javascript函数式编程中的闭包(closure)(javascript的理解)

这段代码中, generateClosure() 函数中有一个局部变量count, 初值为 0。还有一个叫做 get 的函数, get 将其父作用域,也就是 generateClosure() 函数中的 count 变量增加 1,并返回 count 的值。 generateClosure() 的返回值是 get 函数。在外部我们通过 counter 变量调用了 generateClosure() 函数并获取了它的返回值,也就是 get 函数,接下来反复调用几次 counter(),我们发现每次返回的值都递增了 1。 让我们看看上面的例子有什么特点,按照通常命令式编程思维的理解, count 是generateClosure 函数内部的变量,它的生命周期就是 generateClosure 被调用的时期,当 generateClosure 从调用栈中返回时, count 变量申请的空间也就被释放。问题是,在 generateClosure() 调用结束后, counter() 却引用了“已经释放了的” count变量,而且非但没有出错,反而每次调用 counter() 时还修改并返回了 count。这是怎么回事呢? 这正是所谓闭包的特性。当一个函数返回它内部定义的一个函数时,就产生了一个闭包,闭 包 不 但 包 括 被 返 回 的 函 数 , 还包括这个函数的定义环境。上面例子中,当函数generateClosure() 的内部函数 get 被一个外部变量 counter 引用时, counter 和generateClosure() 的局部变量就是一个闭包。如果还不够清晰,下面这个例子可以帮助 你理解:

上面这个例子解释了闭包是如何产生的:counter1 和 counter2 分别调用了 generateClosure() 函数,生成了两个闭包的实例,它们内部引用的 count 变量分别属于各自的运行环境。我们可以理解为,在generateClosure() 返回 get 函数时,私下将 get 可能引用到的 generateClosure() 函数的内部变量(也就是 count 变量)也返回了,并在内存中生成了一个副本,之后 generateClosure() 返回的函数的两个实例 counter1和 counter2 就是相互独立的了。

闭包的用途

1、嵌套的回调函数 闭包有两个主要用途,一是实现嵌套的回调函数,二是隐藏对象的细节。让我们先看下面这段代码示例,了解嵌套的回调函数。如下代码是在 Node.js 中使用 MongoDB 实现一个简单的增加用户的功能:

如果你对 Node.js 或 MongoDB 不熟悉,没关系,不需要去理解细节,只要看清楚大概的逻辑即可。这段代码中用到了闭包的层层嵌套,每一层的嵌套都是一个回调函数。回调函数不会立即执行,而是等待相应请求处理完后由请求的函数回调。我们可以看到,在嵌套的每一层中都有对 callback 的引用,而且最里层还用到了外层定义的 uid 变量。由于闭包机制的存在,即使外层函数已经执行完毕,其作用域内申请的变量也不会释放,因为里层的函数还有可能引用到这些变量,这样就完美地实现了嵌套的异步回调。

2、实现私有成员 我们知道, JavaScript 的对象没有私有属性,也就是说对象的每一个属性都是曝露给外部的。这样可能会有安全隐患,譬如对象的使用者直接修改了某个属性,导致对象内部数据的一致性受到破坏等。 JavaScript通过约定在所有私有属性前加上下划线(例如_myPrivateProp),表示这个属性是私有的,外部对象不应该直接读写它。但这只是个非正式的约定,假设对象的使用者不这么做,有没有更严格的机制呢?答案是有的,通过闭包可以实现。让我们再看看前面那个例子:

我们可以看到,只有调用 counter() 才能访问到闭包内的 count 变量,并按照规则对其增加1,除此之外决无可能用其他方式找到 count 变量。受到这个简单例子的启发,我们可以把一个对象用闭包封装起来,只返回一个“访问器”的对象,即可实现对细节隐藏。

标签: javascript的理解

本文链接地址:https://www.jiuchutong.com/biancheng/377459.html 转载请保留说明!

上一篇:javascript对象的创建和访问(JavaScript对象的创建)

下一篇:一道关于JavaScript变量作用域的面试题(一道关于医用口罩的数学题初二)

  • 折旧年限与税法有关吗
  • 耕地占用税是什么税种
  • 劳务派遣人员的工资计入什么科目
  • 国际货运代理企业应当遵循哪些原则
  • 土建工程维修
  • 跨月能更正个税吗
  • 劳务派遣公司必须设立股东
  • 资产总额和权益总额必然相等吗
  • 一般纳税人的税率是多少个点
  • 劳务派遣代发工资开票
  • 经营性应收项目和经营性应付项目
  • 服务,不动产和无形资产扣除项目本期实际扣除金额
  • 非货币性交换需要确认主营业务收入吗
  • 内控制度包括哪些制度
  • 汇算清缴自查报告
  • 净现值为什么要除以它的折现率
  • 3%税率是一般纳税人还是小规模
  • 非独立核算的分公司如何报税
  • 土地增值税清算是什么意思
  • 新个税劳务报酬怎么算
  • 没有经营的空壳公司可以贷款吗
  • 微众银行账户验证账户0019向您尾号677账户
  • 非营利组织免税资格可以免些什么税
  • 个人独资企业所得税缴纳标准
  • 办公车辆的燃油费过路费怎么报销?
  • 投资利润率的计算结果不受建设期的长短
  • 发票跨期审计调查报告
  • 捐赠计提管理费的账务处理?
  • 招待费进项税额转出在申报表
  • 财务报表包括哪三大报表?(多选)
  • 建筑公司采购制度和流程
  • 长期股权投资凭证
  • 浅谈linux的发展方向和应用范围
  • 域名服务费属于什么会计科目
  • PHP:mcrypt_enc_get_algorithms_name()的用法_Mcrypt函数
  • 场外期权会计核算
  • 用python编写
  • 蓝桥杯真题c语言
  • 管理费用包括哪些会计科目
  • 小规模纳税人房产税优惠政策2023
  • 长期股权投资印花税计入什么科目
  • 社保断交一个月但是后面正常缴费
  • 生产成本有什么
  • 分公司以总公司名义
  • 其他权益工具投资是金融资产吗
  • 将购入的原材料用于不动产在建工程
  • 新会计准则下的资产负债表
  • 小企业在购买商品过程中发生的费用
  • 事故赔偿给谁
  • 淘宝开店的钱怎么取出来
  • 建筑业 成本
  • 税金及附加如何预测
  • 简易计税方法适用什么服务
  • 怎么理解核销
  • 农产品增值税公式
  • 交易性金融资产的账务处理
  • 主营业务收入减少记哪方
  • 公司向员工个人借款怎么处理
  • mysql数据监控
  • Navicat连接MySQL报错
  • linux那些事儿
  • linux bye
  • linux系统的
  • Linux操作系统中怎么永久设置环境变量?
  • perl数组求和
  • 简单 粗暴
  • python数据结构与算法分析 第2版(图灵出品)
  • cocos2dx ui编辑器
  • vue自定义过滤器的语法
  • jquery操作
  • Node.js 中exports 和 module.exports 的区别
  • java栈怎么写
  • shell 批量删除
  • unity5.x游戏开发指南
  • android 自定义dialog
  • Unity3D&&TexturePacker
  • 电梯维护保养费按什么缴纳增值税
  • 申报印花税显示未维护营行业信息
  • 车船税填表说明
  • 安徽省印花税核定
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设