iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >javascript中怎么提高扩展运算符的性能
  • 248
分享到

javascript中怎么提高扩展运算符的性能

2023-06-06 13:06:33 248人浏览 安东尼
摘要

这篇“javascript中怎么提高扩展运算符的性能”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“javascript中怎么提高扩展运算符的性能”,小编整理了以下知识点,请大家跟着小编的步伐一

这篇“javascript中怎么提高扩展运算符的性能”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“javascript中怎么提高扩展运算符的性能”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解,接下来就让我们进入主题吧。

Java可以用来干什么

Java主要应用于:1. web开发;2. Android开发;3. 客户端开发;4. 网页开发;5. 企业级应用开发;6. Java大数据开发;7.游戏开发等。

让我们首先简要介绍一下扩展运算符在数组中的工作原理。

扩展运算符,也就是我们常用的三个,让数组展开变成每个小块。 然后使用中括号语法[],重新组装这些小块构造一个新数组。

扩展运算符可以被放置在中括号[]里面的任何位置。

const numbers = [1, 2, 3];[0, ...numbers];    // => [0, 1, 2, 3][0, ...numbers, 4]; // => [0, 1, 2, 3, 4][...numbers, 4];    // => [1, 2, 3, 4]

回答我们一开始提出的问题,扩展运算符在数组文字中的位置是否可以提高性能?让我们往后继续探究。

附加到头部和尾部功能

在开始性能比较之前,让我们定义两个函数。

第一个是appendToTail()

function appendToTail(item, array) {  return [...array, item];}const numbers = [1, 2, 3];appendToTail(10, numbers); // => [1, 2, 3, 10]

appendToTail()可以让你在数组的末尾插入一个值。 此函数使用了以下写法[...array, item]

第二个是appendToHead()

function appendToHead(item, array) {  return [item, ...array];}const numbers = [1, 2, 3];appendToHead(10, numbers); // => [10, 1, 2, 3]

appendToHead()是一个纯函数,它返回一个新数组,其中添加的值是插入在原数组的头部。它使用[item, ...array]

讲道理就上面这两个函数的表现,没有理由认为这些功能会有不一样的效率。但是事实可能跟我们想象中不一样,下面让我们来继续测试吧。

性能测试

我用MacBook Pro在以下3个浏览器的笔记本电脑上测试[... array, item][item, ...array],对比两者的性能:

  • Chrome 76

  • Firefox 68

  • Safari 12.1

以下是性能测试结果:

javascript中怎么提高扩展运算符的性能

正如预期的那样,在Firefox和Safari浏览器中[...array, item][item, ...array]具有相同的性能。

但是,在Chrome中,[...array, item]的执行速度比[item, ...array]快两倍。 这是一个有用的结果。

要在Chrome中提高扩展运算符的性能,请在数组文字的开头使用扩展运算符:

const result = [...array, item];

但另一个问题出现了:这种问题怎么引起的?

从V8引擎的7.2版本之后,为Chrome中的JavaScript执行提供支持,可以对扩展运算符进行新的优化快速路径优化

用几句话描述它的工作原理,如下:

如果没有这个优化,当引擎遇到扩展运算符[...iterable, item]时,它会调用可迭代对象的迭代器iterator.next()。在每次迭代时,结果数组的内存都会增加,迭代结果会被添加到结果数组中。

但是快速路径优化检测到已知的可迭代(如整数数组)并完全跳过迭代器对象的创建。 然后引擎读取扩展数组的长度,仅为结果数组分配一次内存。 然后通过索引传播数组,将每个项目添加到结果数组中。

快速路径优化会跳过迭代对象的创建,只为结果分配一次内存。 从而性能提高。

支持的数据结构

快速路径优化适用于以下标准JavaScript数据结构。

数组

const numbers = [1, 2, 3, 4];[...numbers, 5]; // => [1, 2, 3, 4, 5]

字符串

const message = 'Hi';[...message, '!']; // => ['H', 'i', '!']

Sets

const colors = new Set(['blue', 'white']);[...colors, 'green'];          // => ['blue', 'white', 'green'][...colors.values(), 'green']; // => ['blue', 'white', 'green'][...colors.keys(), 'green'];   // => ['blue', 'white', 'green']

Maps

在Map对象中,仅支持map.keys()map.values()方法:

const names = new Map([[5, 'five'], [7, 'seven']]);[...names.values(), 'ten']; // => ['five', 'seven', 'ten'][...names.keys(), 10];      // => [5, 7, 10]

以上是“javascript中怎么提高扩展运算符的性能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: javascript中怎么提高扩展运算符的性能

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

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

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

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

下载Word文档
猜你喜欢
  • javascript中怎么提高扩展运算符的性能
    这篇“javascript中怎么提高扩展运算符的性能”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“javascript中怎么提高扩展运算符的性能”,小编整理了以下知识点,请大家跟着小编的步伐一...
    99+
    2023-06-06
  • JavaScript扩展运算符怎么用
    小编给大家分享一下JavaScript扩展运算符怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!复制数组我们可以使用展开操作符复制数组,不过要注意的是这是一个...
    99+
    2023-06-14
  • Cassandra中怎么提高性能和扩展性
    要提高Cassandra的性能和扩展性,可以考虑以下几点: 数据建模优化:设计合理的数据模式,避免数据倾斜和冗余,优化查询性能。...
    99+
    2024-03-15
    Cassandra
  • ES6中扩展运算符怎么用
    这篇文章主要介绍了ES6中扩展运算符怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。扩展运算符  ...可以将数组转换为逗号分隔的参数序...
    99+
    2024-04-02
  • JavaScript中如何使用扩展运算符
    这篇文章给大家介绍JavaScript中如何使用扩展运算符,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。个人对…常用方法的理解…作为扩展运算符这里指的扩展是针对数组或字符串或伪数组(就...
    99+
    2024-04-02
  • JavaScript扩展运算符的简写方法
    这篇文章主要介绍JavaScript扩展运算符的简写方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!扩展运算符简写扩展运算符有几种用例让JavaScript代码更加有效使用,可以用来代替某个数组函数。简写:不像co...
    99+
    2023-06-27
  • ES6中的扩展运算符怎么使用
    这篇文章主要讲解了“ES6中的扩展运算符怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ES6中的扩展运算符怎么使用”吧!ES6的扩展运算符,它的语法...
    99+
    2024-04-02
  • JavaScript中如何使用扩展运算符展开对象
    这篇文章主要为大家展示了“JavaScript中如何使用扩展运算符展开对象”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript中如何使用扩展运算符展开对象”这篇文章吧。展开对象co...
    99+
    2023-06-04
  • JavaScript中运算符与数组扩展详细讲解
    目录运算符扩展运算符指数运算符链判断运算符Null判断运算符逻辑赋值运算符数组扩展方法Array.from()Array.of()copyWithin()find()fill()fl...
    99+
    2022-11-13
    JS运算符与数组扩展 JS数组扩展 JS运算符
  • JS ES扩展运算符怎么使用
    这篇文章主要介绍“JS ES扩展运算符怎么使用”,在日常操作中,相信很多人在JS ES扩展运算符怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JS ES扩展运算符怎么使用...
    99+
    2023-06-21
  • JavaScript中如何使用扩展运算符拷贝数组
    这篇文章将为大家详细讲解有关JavaScript中如何使用扩展运算符拷贝数组,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。拷贝数组const arr = [1, 2...
    99+
    2023-06-05
  • 怎么在python中利用运算符扩展列表
    本篇文章给大家分享的是有关怎么在python中利用运算符扩展列表,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。python的五大特点是什么python的五大特点:1.简单易学,...
    99+
    2023-06-14
  • es6对象扩展运算符怎么应用
    ES6的对象扩展运算符(`...`)可以用于复制对象、合并对象、传递函数参数等多种应用。 复制对象:使用对象扩展运算符可以非常方...
    99+
    2023-10-25
    es6
  • JavaScript扩展运算符的学习及应用详情(ES6)
    目录学习应用函数参数数组合并解构赋值字符串转换转换数组前言: 扩展运算符是ES6新增的一种运算符,他可以帮助我们简化代码,简化操作,所以在开发中是非常常用的,下面我将从学习与应用两个...
    99+
    2022-11-13
    JavaScript扩展运算符应用 JavaScript扩展运算符
  • JavaScript展开运算符和剩余运算符的区别是什么
    这篇文章主要介绍“JavaScript展开运算符和剩余运算符的区别是什么”,在日常操作中,相信很多人在JavaScript展开运算符和剩余运算符的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Jav...
    99+
    2023-06-22
  • JavaScript位运算符怎么运算的
    JavaScript中的位运算符用于对数字的二进制表示进行操作。下面是常见的位运算符及其运算方式:1. 按位与(&):对两个数字的每...
    99+
    2023-10-11
    JavaScript
  • JS中使用扩展运算符的方法有哪些
    本篇内容主要讲解“JS中使用扩展运算符的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JS中使用扩展运算符的方法有哪些”吧!复制数组我们可以使用展开操...
    99+
    2024-04-02
  • Javascript之怎么提高React性能
    本篇内容主要讲解“Javascript之怎么提高React性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Javascript之怎么提高React性能”吧!1.解决重复渲染问题我们大多数人都知...
    99+
    2023-07-05
  • JavaScript中如何使用扩展运算符将类数组转化为数组
    这篇文章主要介绍了JavaScript中如何使用扩展运算符将类数组转化为数组,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。扩展运算符[......
    99+
    2024-04-02
  • PHP 缓存和 Spring:如何提高网站的可扩展性和性能?
    在现代网站开发中,可扩展性和性能是最重要的考虑因素之一。针对这些问题,PHP 缓存和 Spring 框架是两个常用的解决方案。在本文中,我们将探讨如何使用这两个工具来提高网站的可扩展性和性能。 一、PHP 缓存 1.1 什么是 PHP 缓...
    99+
    2023-09-06
    缓存 spring 学习笔记
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作