IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> V8原理及JS性能优化 -> 正文阅读

[JavaScript知识库]V8原理及JS性能优化

一、V8原理

1.垃圾回收机制

JS中的内存管理时自动进行的。如果对象不再被引用或无法从根上访问(通过引用或作用域链),则被认为是垃圾。

GC算法介绍

计数算法

通过设置引用数,判断当前引用是否为0。引用关系改变时修改引用数字。

  • 优点:最大限度减少程序暂停;发现垃圾及时回收。减少程序卡顿
  • 缺点:无法回收循环引用的对象;时间开销大

标记清除算法

通过设置标记清除垃圾,第一次遍历所有对象标记活动的对象,第二次遍历所有对象清除没有标记的对象,回收相应空间

  • 优点:可以回收循环引用的对象
  • 缺点:回收以后内存空间碎片多

标记整理算法

第一次遍历所有对象标记活动对象添加标记。第二次整理活动的对象再清除没有标记的对象

V8

主流的JS执行引擎,采用即时编译,设置内存大小。64位操作系统内存不超过1.5G。32 位操作系统不超过800M

V8垃圾回收策略

基础数据是由程序语言自身控制,主要回收存放在堆区里的对象数据。

  • V8采用分代回收机制,通过存活时间将内存分成新生代和老生代。存活时间短的对象存放于小空间的新生代。
  1. 新生代垃圾回收策略
    将新生代内存分成两个等大的空间。从From空间遍历标记活动对象再遍历拷贝到To空间之后将From空间清空,置换两个空间的状态。一轮GC还存活的对象移动到老生代。当前To空间中的使用率超过25%时也将活动对象移动到老生代。
  2. 老生代垃圾回收策略
    64位操作系统老生代区空间大小1.4G,32位操作系统老生代空间700M。
    标记活动对象,清除垃圾对象。会产生空间,新生代中的对象移动到老生代时如果老生代空间不足会触发标记整理空间优化。采用增量标记进行效率优化。

内存问题的外在表现

  • 页面出现经常性暂停或者延迟加载(内存泄露)开发中常见的内存泄露
  • 页面持续出现糟糕的性能(内存膨胀)
  • 页面的性能随着时间加长越来越差(频繁垃圾回收)

监控内存的方式

  1. 浏览器任务管理器
    使用Shift+ESC调出浏览器任务管理器。第一列内存指的是DOM节点占据的内存,JS内存表示JS堆括号中的大小指的是界面中所有可达对象中正在使用的内存大小。只能检测无法定位问题
  2. Timeline时序图
    Chrome调试工具中
  3. 堆块照查找分离DOM
    分离DOM:界面元素存活在DOM树上,没被引用的DOM是垃圾对象,脱离当前DOM树但在js中有引用称为分离状态的DOM节点。分离的DOM存在内存泄露的现象
  4. 判断是否频繁垃圾回收
    GC工作时应用程序时停止的,频繁且过长的GC会导致应用假死。用户使用时有明显的 卡顿。
    通过判断Timeline时序图中频繁的上升下降或者任务管理器中数据频繁增加减小

JS性能优化

  1. 使用Jsperf比较运行效率
  2. 避免定义全局变量
  3. 将全局变量缓存到某一作用域使用
  4. 通过原型对象新增方法
var fn =function(){}
fn.prototype.foo = function(){
	console.log('111')
}
  1. 避开闭包陷阱
    在函数外部引用内部成员,使得内部成员无法被垃圾回收释放,造成内存泄露
<button id="btn">add</button>
<script>
function foo(){
  var el = document.getElementById('btn')	//页面上的该元素是活动的对象,在函数内部再次被引用
  el.onclick =function(){
	console.log(el.id)	
  }
  el = null 	//将el设置为null在作用外部销毁闭包释放内存
}
foo()			//onclick是用户点击触发函数,点击时函数作用域已经被销毁,但引用作用域内部数据。满足闭包条件
</script>
  1. 避免属性访问方法使用
    JS无需属性的访问方法,所有属性外部可见。使用属性访问方法只会增加一层定义,没有具体的访问控制力
  2. For循环优化
    将for循环的次数提前存储。
    如果只遍历数据而无操作时执行效率 forEach >for in > for
  3. 文档碎片优化节点添加
    节点的添加比然会有回流和重绘。利用文档碎片的容器将节点集中渲染然后一次性添加到DOM之上。能够减少回流和重绘的次数
const flag = document.createDocumentFragment()
	for(var i = 0; i< 10;i++){
		var op = document.createElement('p')
		op.innerHTML = i
		flag.append(op)
	}
document.body.appendChild(flag)
  1. 克隆优化节点操作
    可以通过克隆的方式创建节点, 再将子节点添加到该节点上
var oldP = document.getElementById('box1')
for(var i = 0; i<3;i++){
	var newP = oldP.cloneNode(false)
	newP.innerHTML = i
	document.body.appendChild(newP)
}

JSBench工具

JSBench工具链接

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-08 22:20:01  更:2022-03-08 22:23:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:27:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码