iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >reduce lodash.reduce实现原理是什么
  • 661
分享到

reduce lodash.reduce实现原理是什么

2023-07-05 06:07:17 661人浏览 泡泡鱼
摘要

本篇内容主要讲解“reduce lodash.reduce实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“reduce lodash.reduce实现原理是什么”吧!基本实现实现思路

本篇内容主要讲解“reduce lodash.reduce实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“reduce lodash.reduce实现原理是什么”吧!

基本实现

实现思路:

  • 判断是否有初始值,因为有初始值和没有初始值对回调函数(reducer)执行的次数是有影响的。

  • 遍历数组

  • 组合参数传递给 reducer 进行执行

  • 获取到第三步返回值的时候,要把返回值存储起来,在下一次便利的时候作为reducer第一个参数来替换初始值。

  • 返回最终计算的value值

function reduce(array, reducer, initialValue = null) {    let value = initialValue === null ? array[0] : initialValue; // 思路1    let startIndex = initialValue === null ? 1 : 0; // 思路1    for(let i = startIndex; i < array.length; i++) { // 思路 2        const item = array[i]        const res = reducer(value, item, i) // 思路3        value = res; // 思路4    }    return value; // 思路5}

测试一下:

console.log(reduce([1,2,3], (a, b) => (a + b), 0)) // 6console.log(reduce([1,2,3], (a, b) => (a + b))) // 6

看起来是不是挺简单的,代码其实还可以更简洁一点:

function reduce(array, reducer, value = null) {    value = value === null ? array[0] : value;    for(let i = null ? 1 : 0; i < array.length; i++) {        value = reducer(value, array[i], i);    }    return value;}

lodash 中的 reduce 实现有何不同?

lodash中 的 reduce 不仅可以对数组生效,也可以对普通 object 、类数组对象生效。

不过也针对数组其实单独实现了一个 arrayReduce 函数,不过没有对外。

来看一下 reducearrayReduce 源码

function reduce(collection, iteratee, accumulator) {  const func = Array.isArray(collection) ? arrayReduce : baseReduce  const initAccum = arguments.length < 3  return func(collection, iteratee, accumulator, initAccum, baseEach)}function arrayReduce(array, iteratee, accumulator, initAccum) {  let index = -1  const length = array == null ? 0 : array.length  if (initAccum && length) {    accumulator = array[++index]  }  while (++index < length) {    accumulator = iteratee(accumulator, array[index], index, array)  }  return accumulator}

看得懂吗?不理解的话看下面一份代码,我把非数组类型的代码去掉,再调一下变量命名和新增注释:

function reduce(array, reducer, value) {  const noInitialValue = arguments.length < 3 // 用参数的数量来判断是否有初始值    let index = -1 // 遍历索引 - 1,因为下面 while 循环前先加了 1  const length = array == null ? 0 : array.length // 判断数组是否存在和缓存数组长度  // 这个if 语句中做了我上面思路1中初始值的问题和遍历次数的问题  if (noInitialValue && length) { // && length 判断了数组是否为空    value = array[++index] // 没有有初始值,则取数组中第一为,注意 index 变成了0,下面 while 循环前会先加 1,因此循环次数会少一次。  }  while (++index < length) {    value = reducer(value, array[index], index, array)  }  return value}

可以看出其实大部分逻辑还是和前面的简单实现差不多,不过考虑更全一些,有值得借鉴的地方:

  • 参数判断逻辑更有力,不管外界传递了第三个参数是啥,都说明有初始值

  • 考虑了数组不存在或者为空的情况

下面我们再看一下,去除数组相关的代码来看看针对其他对象类型怎么处理的。

function reduce(collection, iteratee, accumulator) {  const func = baseReduce;  const initAccum = arguments.length < 3  return func(collection, iteratee, accumulator, initAccum, baseEach)}

其他类型的都会教给 baseReduce 函数去处理。

// baseReducefunction baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {  // 使用外部传递进来的遍历方法进行遍历对象,然后传递了一个 callback 给 eachFunc  eachFunc(collection, (value, index, collection) => {    // 初始值设置,    accumulator = initAccum      ? (initAccum = false, value)      : iteratee(accumulator, value, index, collection)  })  return accumulator}

使用外部传递进来的遍历方法进行遍历对象,然后传递了一个 callback 给 eachFunc,来执行 iteratee (也就是前面说的reducer),callback 内部的代码就和前面 for 循环或者 while 循环的代码类似的,就是组合参数传递给 reducer 进行执行,不过直接看可能有点不好理解中,了解了原理再来看应该可以理解,注意事项:

  • initAccum 为 false 时,说明有初始值,直接执行 iteratee。

  • initAccum 为 true,说明没有初始值,需要添加初始值,因此第一次循环就是赋值给初始值,然后把 initAccum 设置为false,没有进行执行 iteratee,比没有初始值少一次执行,符合逻辑。

eachFunc 用的是 reduce 中传递进来的 baseEach,内部主要就是对对象属性进行遍历的操作,然后把属性值和索引以及对象本身传递给 callback,稍微需要注意的就是可能遇到类数组的对象,为了保证顺序,使用类数组放入索引进行遍历,而其他对象并不能保证属性的传递顺序,可以再看一下baseEach实现的代码:

function baseEach(collection, iteratee) {  if (collection == null) {    return collection  }  // 不是类数组则使用 baseForOwn 处理  if (!isArrayLike(collection)) {    return baseForOwn(collection, iteratee)  }  const length = collection.length  const iterable = Object(collection) // 使用arguments测试了一下,好像没啥作用  let index = -1  // 遍历类数组  while (++index < length) {    if (iteratee(iterable[index], index, iterable) === false) {      break    }  }  return collection}

不是 isArrayLike 的对象遍历与本篇文章的内容没有啥关系了,因此就不深入了。

到此,相信大家对“reduce lodash.reduce实现原理是什么”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: reduce lodash.reduce实现原理是什么

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

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

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

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

下载Word文档
猜你喜欢
  • reduce lodash.reduce实现原理是什么
    本篇内容主要讲解“reduce lodash.reduce实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“reduce lodash.reduce实现原理是什么”吧!基本实现实现思路...
    99+
    2023-07-05
  • reduce探索lodash.reduce实现原理解析
    目录前言基本实现lodash 中的 reduce 实现有何不同?总结前言 前一篇 你真的了解Array.reduce吗? 讲解了 reduce 基础使用方法和场景的运用场景。本篇来分...
    99+
    2023-02-27
    reduce lodash.reduce reduce原理
  • SSH的实现原理是什么
    本篇内容介绍了“SSH的实现原理是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!SSH是一种协议标准,它的主要目的是实现远程登录和提供安...
    99+
    2023-06-17
  • SpringCloud-Hystrix实现原理是什么
    这篇文章给大家分享的是有关SpringCloud-Hystrix实现原理是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、思维导图二、Hystrix包含的内容(1) 服务降级1)什么是服务降级有了服务的熔断...
    99+
    2023-06-15
  • chatgpt的实现原理是什么
    本文小编为大家详细介绍“chatgpt的实现原理是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“chatgpt的实现原理是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。...
    99+
    2023-02-21
    chatgpt
  • CountDownLatch的实现原理是什么
    这篇文章主要讲解了“CountDownLatch的实现原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CountDownLatch的实现原理是什么”吧! 前言CountDo...
    99+
    2023-06-15
  • Linux的实现原理是什么
    本篇内容主要讲解“Linux的实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux的实现原理是什么”吧!1 引言90年代以来,数控技术发展的一个重要趋势是数控系统的开放化。目前...
    99+
    2023-06-16
  • sync.Pool的实现原理是什么
    本篇内容主要讲解“sync.Pool的实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sync.Pool的实现原理是什么”吧!sync.Pool实现原理对象的创建和销毁会消耗一定的系...
    99+
    2023-06-19
  • CAS的实现原理是什么
    本篇内容主要讲解“CAS的实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CAS的实现原理是什么”吧!悲观锁与乐观锁悲观锁总是假设最坏的情况,线程a...
    99+
    2024-04-02
  • MongoDB中实现原理是什么
    今天就跟大家聊聊有关MongoDB中实现原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。主流程MyCAT Server 接收 MySQL C...
    99+
    2024-04-02
  • ConcurrentHashMap的实现原理是什么
    这篇文章将为大家详细讲解有关ConcurrentHashMap的实现原理是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.HashTable与ConcurrentHashMap的对比H...
    99+
    2023-06-19
  • LongAdder的实现原理是什么
    LongAdder的实现原理是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。AtomicLong的实现原理图:LongAdder是JDK8...
    99+
    2024-04-02
  • vuex的实现原理是什么
    本篇内容主要讲解“vuex的实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vuex的实现原理是什么”吧!关于vuex就不再赘述,简单回顾一下:当应用碰到多个组件共享状态时,简单的单...
    99+
    2023-07-05
  • Go channel实现原理是什么
    本篇内容主要讲解“Go channel实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Go channel实现原理是什么”吧!channel单纯地将函数并发执行是...
    99+
    2023-07-05
  • golang map实现原理是什么
    Golang中的map是一种哈希表数据结构,用于存储键值对。它的实现原理是使用哈希函数将键映射到哈希表中的一个桶(bucket),每...
    99+
    2023-08-15
    golang map
  • hooks的实现原理是什么
    Hooks是React 16.8版本引入的一种新特性,它可以让我们在不编写class的情况下使用state和其他React的特性。H...
    99+
    2023-10-10
    hooks
  • java原子类实现的原理是什么
    Java原子类的实现原理是利用了底层的CAS(Compare and Swap)操作。CAS是一种乐观锁机制,它包含三个参数:内存位...
    99+
    2023-10-18
    java
  • Docker exec的实现原理是什么
    本篇内容主要讲解“Docker exec的实现原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Docker exec的实现原理是什么”吧!我使用了 docker ex...
    99+
    2023-06-29
  • mysql driver的实现原理是什么
    MySQL驱动的实现原理是通过与MySQL数据库进行通信来实现与数据库的连接和操作。 具体来说,MySQL驱动使用Socket来与M...
    99+
    2024-04-09
    mysql
  • LAMP架构实现原理是什么
    LAMP架构是一种常用的Web应用程序开发和部署架构,它由以下四个核心组件组成:1. Linux操作系统:作为底层操作系统,提供了稳...
    99+
    2023-09-21
    LAMP
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作