JavaScript:CPU缓存预取以及确定数据下直接更改数组length的好处
CPU缓存预取以及确定数据下直接更改数组length的好处
- 1. CPU 缓存预取(Cache Preloading):
- CPU 缓存预取:
- 为什么反向填充栈能利用缓存预取:
- 2. 为什么可以直接改变数组的 length:
- 数组的动态长度:
- 为什么可以直接改变 length:
- 性能考虑:
- 总结:
1. CPU 缓存预取(Cache Preloading):
在这段代码中,findFSTNodeByDataName 使用了一个 stack 数组来存储待处理的节点,并且通过反向填充栈来优化性能,特别是在 CPU 缓存的使用上。
const stack = new Array(payload.length);
let stackIdx = payload.length;// 反向填充初始栈(利用 CPU 缓存预取)
for (let i = 0; i < payload.length; i++) {stack[i] = payload[i];
}
CPU 缓存预取:
- 在现代计算机中,CPU 会使用缓存(例如 L1/L2 缓存)来提高内存访问速度。访问较远的内存地址(比如跨越不同缓存块的数据)可能会导致较慢的访问速度。为了提高效率,CPU 会预取(预加载)一些内存块,提前将它们加载到缓存中,以减少等待时间。
为什么反向填充栈能利用缓存预取:
- 由于 stack[i] = payload[i] 是顺序访问数组的元素,而数组通常是按顺序存储在内存中的(尤其是在大数组或一维数组中)。访问内存时,CPU 会预取接下来的内存区域,因为数组的内存是线性分布的。因此,在这个循环中,填充栈的过程本身会触发CPU预取操作,使得数据在栈上被预加载,后续的栈操作就能更高效地访问这些数据。
- 更进一步,现代 JavaScript 引擎和操作系统会在物理内存中对数据进行布局优化,使得连续的内存区域更有可能被缓存(如数组元素连续存储在内存中)。通过反向填充(从栈顶往下填充),代码可能更好地利用了 CPU 的预取机制,提高了内存访问的效率。
2. 为什么可以直接改变数组的 length:
在这段代码中,当栈中某个节点有子节点时,代码改变了 stack 数组的 length:
const children = node.children;
if (children?.length) {const childLen = children.length;stack.length = stackIdx + childLen; // 改变数组长度for (let j = 0; j < childLen; j++) {stack[stackIdx + j] = children[j];}stackIdx += childLen;
}
数组的动态长度:
- 在 JavaScript 中,数组的 length 是一个动态属性,你可以随时通过设置 length 来扩展或收缩数组。当你设置 stack.length = stackIdx + childLen 时,实际上是调整了数组的大小,使它容纳更多的元素。需要注意的是,改变数组 length 只会影响已分配的数组内存(对于扩展数组会重新分配内存)。
为什么可以直接改变 length:
- JavaScript 数组是动态的,它们可以按需增加或缩小。虽然 length 是一个特殊的属性,但它与数组的元素存储是分开的。这使得在访问数组元素时,设置 length 会自动调整数组的大小,且这种操作不需要手动分配新的内存。JavaScript 引擎内部会自动管理数组内存的重新分配或收缩。
- 在这段代码中,stack.length = stackIdx + childLen 是为了将栈的长度调整到适应当前子节点的数量。这种做法与使用 push 或 unshift 添加元素相比,性能上会更高。通过直接设置 length,数组的内存布局会被调整,以便为新元素腾出空间。更重要的是,length 的操作不会导致 push 的隐式内存分配和元素复制过程。
性能考虑:
- 当你直接设置 length 时,相比 push 或 unshift,通常会避免不必要的内存重新分配和复制,尤其是在元素的数量已知或变化可控的情况下。这种方式避免了多次进行内存扩容操作,提高了性能。
总结:
1. CPU 缓存预取:通过反向填充栈,可以利用 CPU 的预取机制,提高内存访问效率。这种方法优化了内存布局,避免了频繁的随机内存访问,提高了缓存命中率。
2. 直接改变 length 的原因:在 JavaScript 中,数组的 length 可以直接修改,它是一个动态的属性。修改 length 不需要进行数组的复制或其他操作,因此相比 push 等方法,能更高效地调整数组的大小,避免了不必要的内存分配和数据复制。
这种技术的组合方式(使用反向填充和调整数组 length)可以帮助提升性能,尤其是在处理大量数据时,减少内存分配和复制的开销,进而提高算法效率。
相关文章:
JavaScript:CPU缓存预取以及确定数据下直接更改数组length的好处
CPU缓存预取以及确定数据下直接更改数组length的好处 1. CPU 缓存预取(Cache Preloading):CPU 缓存预取:为什么反向填充栈能利用缓存预取: 2. 为什么可以直接改变数组的 length:数组的动态长度:…...
Selenium常用自动化函数
博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:数据库 JavaEE专栏:JavaEE 软件测试专栏:软件测试 关注博主带你了解更多知识 目录 1.元素的定位 1.1 定位步骤 1,要想定位,就先打开开发者工具 2,先点击左上角图标 1.2 cssSelector 1.3 xpath 2.操作测…...
【故障排除】ls: command not found 终端命令失效的解决办法
【TroubleShooting】ls: command not found 终端命令失效的解决办法 A Solution to Solve “Command not found” of Terminal on Mac 一直在使用心爱的MacBook Pro的Terminal,并且为她定制了不同的Profile。 这样,看起来她可以在不同季节,…...
OpenStack-Train版-Allinone自动化部署脚本
一、环境准备 操作系统:CentOS 7 或以上版本 建议配置: CPU:8 核或以上 内存:16 GB 或以上 磁盘:500 GB 或以上 网络配置: 确保虚拟机已配置静态 IP 地址 确保虚拟机可以正常访问外部网络 二、自动…...
12.翻转、对称二叉树,二叉树的深度
反转二叉树 递归写法 很简单 class Solution { public:TreeNode* invertTree(TreeNode* root) {if(rootnullptr)return root;TreeNode* tmp;tmproot->left;root->leftroot->right;root->righttmp;invertTree(root->left);invertTree(root->right);return …...
新电脑配置安装下载
1、谷歌浏览器 地址https://www.google.cn/chrome/ 下载安装即可。 2、nvm下载 下载地址:地址https://nvm.uihtm.com/#google_vignette nvm install 相对应的node版本 // 安装 nvm list 可以查看已下载的node版本 // 查看 nvm use 相对应的node版本号 // 使用 nv…...
数字孪生智慧停车管理可视化平台
采用图扑可视化技术搭建智慧停车管理平台,实现了全面的数据整合与实时监控,提升了停车场运营效率和用户体验。通过 HT 可视化界面,管理者能够实时观察和分析停车位使用情况,进行精准调度与优化决策。...
win10 llamafactory模型微调相关②
微调 使用微调神器LLaMA-Factory轻松改变大语言模型的自我认知_llamafactory 自我认知-CSDN博客 【大模型微调】使用Llama Factory实现中文llama3微调_哔哩哔哩_bilibili 样本数据集 (数据集管理脚本处需更改,见报错解决参考1) 自我认知微…...
车载测试工具 --- CANoe VH6501 进行Not Acknowledge (NAck) 测试
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 简单,单纯,喜欢独处,独来独往,不易合同频过着接地气的生活,除了生存温饱问题之外,没有什么过多的欲望,表面看起来很高冷,内心热情,如果你身…...
Mysql中存储引擎各种介绍以及应用场景、优缺点
概述 MySQL 提供了多种存储引擎,每种引擎有不同的特点和适用场景。以下是几种常见的 MySQL 存储引擎的详细介绍,包括它们的底层工作原理、优缺点,以及为什么 MySQL 默认选择某种引擎。 1. InnoDB 底层工作原理: 事务支持&#…...
使用 AlexNet 实现图片分类 | PyTorch 深度学习实战
前一篇文章,CNN 卷积神经网络处理图片任务 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章内容来自于 强化学习必修课:引领人工智能新时代【梗直哥瞿炜】 使用 AlexNet 实现图片分类…...
Linux系统引导与服务管理
目录 一、Linux引导过程 1、引导过程概述 1.1、BIOS开机自检 1.2、MBR读取 1.3、加载引导加载程序(GRUB) 1.4、内核加载 1.5、初始化进程(init) 二、服务 2.1、服务类型 2.2、服务管理工具 三、运行级别 四、systemd …...
【Hadoop】大数据权限管理工具Ranger2.1.0编译
目录 编辑一、下载 ranger源码并编译 二、报错信息 报错1 报错2 报错3 报错4 一、下载 ranger源码并编译 ranger官网 https://ranger.apache.org/download.html 由于Ranger不提供二进制安装包,故需要maven编译。安装其它依赖: yum install gcc …...
宝珀(Blancpain):传承近三百年的机械制表传奇(中英双语)
宝珀(Blancpain):传承近三百年的机械制表传奇 在钟表行业中,宝珀(Blancpain) 作为世界上最古老的制表品牌,一直以其卓越的机械工艺、复杂功能腕表和对创新的坚持而闻名。自 1735 年成立以来&am…...
【Linux】Linux命令:crontab
目录 1、作用2、命令使用格式3、常用参数说明4、时程表4.1 格式4.2 常见问题处理 5、示例 1、作用 crontab命令用于对用户的时程表进行查看、删除、修改等操作。 用户的时程表是用于记录着要定期执行的程序。当安装完Linux操作系统启动后, cron服务会定期执行时程表…...
C++ 使用CURL开源库实现Http/Https的get/post请求进行字串和文件传输
CURL开源库介绍 CURL 是一个功能强大的开源库,用于在各种平台上进行网络数据传输。它支持众多的网络协议,像 HTTP、HTTPS、FTP、SMTP 等,能让开发者方便地在程序里实现与远程服务器的通信。 CURL 可以在 Windows、Linux、macOS 等多种操作系…...
浙江大华社招面试
下面是我之前社招面试大华时,面得是嵌入式Linux系统工程师,下面是我初试所被问到的问题分享给大家 毕业之后工作负责过哪些产品,工作负责哪些内容 Camera相关 1、调试sensor是多少像素 2、板子上怎么连接sensor 3、几LINE 4、每个LINE的data rate 是多少 ,单位是什么 5、图…...
多对多的增删改查
一 : 增 随机单号: /*** 文档就绪函数*/$(function () {//随机单号let number Math.floor(Math.random()*(9999-10001)1000);//取随机单号的值 固定格式输出$("#docNo").val(BSnumber);}) 开单日期: //处理开单日期$("#invoiceDate").val(new Date().to…...
vscode设置保存时自动缩进和格式化
参考博客 如何在 VSCode 中自动缩进你的代码 | Linux 中国 省流 使用 Ctrl Shift P 来打开命令模式,搜索 Open User Settings 并按下回车你需要搜索 Auto Indent,并在 “编辑器:自动缩进(Editor: Auto Indent)” 中选择 “全部(Full)”P…...
【练习】PAT 乙 1074 宇宙无敌加法器
题目 地球人习惯使用十进制数,并且默认一个数字的每一位都是十进制的。而在PAT星人开挂的世界里,每个数字的每一位都是不同进制的,这种神奇的数字称为“PAT数”。每个PAT星人都必须熟记各位数字的进制表,例如“……0527”就表示最…...
探店小程序:解锁商业新生态,定制未来
在数字化浪潮席卷全球的今天,商业的边界正在被重新定义。随着移动互联网技术的飞速发展,探店小程序作为一种新兴的商业模式,正以其独特的优势迅速成为连接商家与消费者的桥梁。我们刚刚为一家客户成功交付了一款集分销、分润、商业模式定制开…...
计算机视觉核心任务
1. 计算机视频重要分类 计算机视觉的重要任务可以大致分为以下几类: 1. 图像分类(Image Classification) 识别图像属于哪个类别,例如猫、狗、汽车等。 应用场景:物品识别、人脸识别、医疗影像分类。代表模型&#…...
【人工智能】如何在VSCode中使用DeepSeek?
文章目录 前言一、准备工作二、安装DeepSeek插件步骤1、扩展图标搜索DeepSeep2、安装DeepSeek插件3、使用测试DeepSeekBito文心一言 结论 前言 介绍在VSCode中调用DeepSeek插件工具,可以进行对话、编码。 一、准备工作 确保已经安装好了VSCode软件。 二、安装D…...
机器学习 - 进一步理解最大似然估计和高斯分布的关系
一、高斯分布得到的是一个概率吗? 高斯分布(也称为正态分布)描述的是随机变量在某范围内取值的概率分布情况。其概率密度函数(PDF)为: 其中,μ 是均值,σ 是标准差。 需要注意的是…...
Office/WPS接入DeepSeek等多个AI工具,开启办公新模式!
在现代职场中,Office办公套件已成为工作和学习的必备工具,其功能强大但复杂,熟练掌握需要系统的学习。为了简化操作,使每个人都能轻松使用各种功能,市场上涌现出各类办公插件。这些插件不仅提升了用户体验,…...
如何在Android Studio中开发一个简单的Android应用?
Android Studio是开发Android应用的官方集成开发环境(IDE),它提供了许多强大的功能,使得开发者能够高效地创建Android应用。如果你是Android开发的初学者,本文将引导你如何在Android Studio中开发一个简单的Android应用…...
第40天:Web开发-JS应用VueJS框架Vite构建启动打包渲染XSS源码泄露代码审计
#知识点 1、安全开发-VueJS-搭建启动&打包安全 2、安全开发-VueJS-源码泄漏&代码审计 一、Vue搭建创建项目启动项目 1、Vue 框架搭建->基于nodejs搭建,安装nodejs即可 参考:https://cn.vuejs.org/ 已安装18.3或更高版本的Node.js 2、Vue 创建…...
996引擎-问题处理:三职业改单职业
996引擎-问题处理:三职业改单职业 问题解决方案顺便补充点单性别设置补充:可视化配置表参考资料问题 目前的版本: 引擎版本号:2024.8.7.0 三端配套客户端:3.40.9 传统PC客户端:23.12.07 配套数据库:64_24.8.7.0此版本需要通过可视化配置表...
Lua语言的云计算
Lua语言在云计算中的应用 随着信息技术的迅猛发展,云计算已经成为现代计算的重要组成部分。云计算通过互联网将计算资源(如服务器、存储、数据库、网络等)进行动态调配和高效利用,极大地提高了资源利用率与开发效率。在众多编程语…...
[数据结构] Set的使用与注意事项
目录 Set的说明 常见方法说明 注意事项 TreeSet使用案例 Set的说明 Set与Map主要的不同有两点: Set是继承自Collection的接口类,Set中只存储了Key. 常见方法说明 方法解释boolean add(E e)添加元素,但重复元素不会被添加成功void clear()清空集合boolean contains(Object…...
