位置: 编程技术 - 正文

深入剖析JavaScript中的函数currying柯里化(深入剖析kubernetes pdf)

编辑:rootadmin

推荐整理分享深入剖析JavaScript中的函数currying柯里化(深入剖析kubernetes pdf),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入剖析大国关系深刻调整对世界格局的影响,深入剖析思想根源的问题,深入剖析大国关系深刻调整对世界格局的影响,深入剖析反面典型案例,深入剖析kubernetes,深入剖析大国关系深刻调整对世界格局的影响,深入剖析正反面典型案例,深入剖析反面典型案例,内容如对您有帮助,希望把文章链接给更多的朋友!

curry化来源与数学家 Haskell Curry的名字 (编程语言 Haskell也是以他的名字命名)。 柯里化通常也称部分求值,其含义是给函数分步传递参数,每次传递参数后部分应用参数,并返回一个更具体的函数接受剩下的参数,这中间可嵌套多层这样的接受部分参数函数,直至返回最后结果。

因此柯里化的过程是逐步传参,逐步缩小函数的适用范围,逐步求解的过程。

柯里化一个求和函数 按照分步求值,我们看一个简单的例子

可以看到, concat3WordsCurrying("foo ") 是一个 Function,每次调用都返回一个新的函数,该函数接受另一个调用,然后又返回一个新的函数,直至最后返回结果,分布求解,层层递进。(PS:这里利用了闭包的特点)

那么现在我们更进一步,如果要求可传递的参数不止3个,可以传任意多个参数,当不传参数时输出结果?

首先来个普通的实现:

但如果要求把每个数乘以之后再相加,那么:

好在有 map 和 reduce 函数,假如按照这个模式,现在要把每项加1,再汇总,那么我们需要更换map中的函数。

下面看一下柯里化实现:

上面 adder是柯里化了的函数,它返回一个新的函数,新的函数接收可分批次接受新的参数,延迟到最后一次计算。

通用的柯里化函数

深入剖析JavaScript中的函数currying柯里化(深入剖析kubernetes pdf)

更典型的柯里化会把最后一次的计算封装进一个函数中,再把这个函数作为参数传入柯里化函数,这样即清晰,又灵活。

例如 每项乘以, 我们可以把处理函数作为参数传入:

这样 sum = currying(multi),调用非常清晰,使用效果也堪称绚丽,例如要累加多个值,可以把多个值作为做个参数 sum(1,2,3),也可以支持链式的调用,sum(1)(2)(3) 柯里化的基础

上面的代码其实是一个高阶函数(high-order function), 高阶函数是指操作函数的函数,它接收一个或者多个函数作为参数,并返回一个新函数。此外,还依赖与闭包的特性,来保存中间过程中输入的参数。即: 函数可以作为参数传递 函数能够作为函数的返回值 闭包 柯里化的作用 延迟计算。上面的例子已经比较好低说明了。

参数复用。当在多次调用同一个函数,并且传递的参数绝大多数是相同的,那么该函数可能是一个很好的柯里化候选。

动态创建函数。这可以是在部分计算出结果后,在此基础上动态生成新的函数处理后面的业务,这样省略了重复计算。或者可以通过将要传入调用函数的参数子集,部分应用到函数中,从而动态创造出一个新函数,这个新函数保存了重复传入的参数(以后不必每次都传)。例如,事件浏览器添加事件的辅助方法:

每次添加事件处理都要执行一遍 if...else...,其实在一个浏览器中只要一次判定就可以了,把根据一次判定之后的结果动态生成新的函数,以后就不必重新计算。

这个例子,第一次 if...else... 判断之后,完成了部分计算,动态创建新的函数来处理后面传入的参数,这是一个典型的柯里化。 Function.prototype.bind 方法也是柯里化应用

与 call/apply 方法直接执行不同,bind 方法 将第一个参数设置为函数执行的上下文,其他参数依次传递给调用方法(函数的主体本身不执行,可以看成是延迟执行),并动态创建返回一个新的函数, 这符合柯里化特点。

下面是一个 bind 函数的模拟,testBind 创建并返回新的函数,在新的函数中将真正要执行业务的函数绑定到实参传入的上下文,延迟执行了。

这里要注意 prototype 中 this 的理解。

以上这篇深入剖析JavaScript中的函数currying 柯里化就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

浅析Javascript中bind()方法的使用与实现 在讨论bind()方法之前我们先来看一道题目:varaltwrite=document.write;altwrite("hello");//1.以上代码有什么问题//2.正确操作是怎样的//3.bind()方法怎么实现对于上

js简单倒计时实现代码 本文实例讲述了js简单倒计时实现代码。分享给大家供大家参考,具体如下:divclass="time"距离活动结束还有spanid="day"/span天spanid="hours"/span小时spanid="min"/sp

js实现精确到秒的日期选择器完整实例 本文实例讲述了js实现精确到秒的日期选择器。分享给大家供大家参考,具体如下:script//主调用函数是setday(this,[object])和setday(this),[object]是控件输出

标签: 深入剖析kubernetes pdf

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

上一篇:javascript中利用柯里化函数实现bind方法【推荐】(javascript如何调用)

下一篇:浅析Javascript中bind()方法的使用与实现(javascript详解)

  • 差额征税怎么填写申报表
  • 现金流量表和利润表关系
  • 如何区分总额法和净额法
  • 个人独资企业经营所得税税率表2023
  • 借款利息支出全部可以税前扣除吗
  • 加盖发票专用章的是
  • 税务局返还的个税手续费税率
  • 支付技术转让费能加计扣除
  • 初始数据试算表不平衡的原因
  • 非经营活动界定,主要说明哪些情形不交增值税
  • 国税几年都没有缴纳
  • 转让法人要注意什么
  • 个体经营户如何开电子发票
  • 增值税专用发票几个点
  • 异地预缴增值税后本地还要交吗
  • 文化用品有哪些种类
  • 对外出租设备
  • 发票不验旧可以领取新的吗
  • 实收资本的会计处理
  • 企业的其他业务收入有
  • 收到投资者投入设备一台,价值100000元
  • 建筑公司购买的材料计入什么科目
  • 附有销售退回条款的递延所得税问题
  • mac系统如何连接北通手柄
  • outlook永久保留邮件
  • 行纪合同的效力
  • windows更新暂停怎么恢复
  • php如何实现
  • 建立无法轻易删除的数据
  • 电脑bios找不到vt
  • window10黑白模式
  • php中的require
  • 2021最好的固态
  • 收到银行汇票怎么背书
  • 会计月末账务处理流程图
  • wordpress使用
  • yii2 页面底部加载css和js的技巧
  • wisdm数据集
  • node使用axios
  • pytorch例程
  • 常用的绘图比例有哪些?
  • 个税在工资里怎么计提
  • 商贸公司会计成本核算
  • 微信收款计入哪个科目
  • 什么是增值税举个例子
  • 不同会计制度资产负债表金额不一样
  • 帝国cms如何使用
  • 销售商品尚未发出会计分录
  • 计提增值税的会计凭证
  • 申报错误后处理有影响吗
  • 发票冲红字蓝字怎么处理
  • 同一控制下的长投入账价值按什么计算
  • 手工账做账流程总结
  • 收到服务费发票可以计入什么科目
  • 以前年度多计提成本怎么处理
  • 话费充值发票可以开公司抬头吗
  • 小规模纳税人申请一般纳税人流程
  • 直接收到货款也要走应收账款吗
  • 低值易耗品怎么做账务处理
  • 会计凭证中阿拉伯数字如何书写
  • iis设置mime
  • mac怎么修改默认应用
  • rftray.exe - rftray是什么进程 有什么用
  • SetPoint.exe - SetPoint是什么进程 有什么用
  • 如何清楚windows搜索记录
  • Win8系统怎么安装
  • win8图标大小怎么调
  • Ext4.2的Ext.grid.plugin.RowExpander无法触发事件解决办法
  • android天气预报开发极简
  • unity3d跑酷游戏教程
  • JavaScript中OnLoad几种使用方法
  • 在javascript中
  • Adding iAd in your App from Unity3d
  • javascript函数如何定义及其作用
  • js过滤特殊字符
  • python自动化运维教程
  • JQuery EasyUI Layout 在from布局自适应窗口大小的实现方法
  • 附加税申报表怎么做
  • 单位纪检员和纪检委员区别
  • 如何在个税app中设置企业登录密码
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设