相信我,面试的基调从一开始就定好了。面试官是往死里问还是往平里问,这都取决于看起来简单却需要猛料的回答。
1.地道解释一下内存泄露
内存泄露的解释:程序中己动态分配的堆内存由于某种原因未释放或无法释放。
面试官:那究竟是什么原因导致没有释放呢?
-
根据JS的垃圾回收机制,当内存中引用的次数为0的时候内存才会被回收
-
全局执行上下文中的对象被标记为不再使用才会被释放
2.内存泄露的几种场景
- 全局变量过多。
通常是变量未被定义或者胡乱引用了全局变量
// main.js
// 场景1
function a(){
b=10;
}
a();
b++;
// 场景2
setTimeout(()=>{
console.log(b)
},1000)
- 闭包。 未手动解决必包遗留的内存引用。
定义了闭包就要消除闭包带来的副作用。
function closuer (){
const b = 0;
return ©=> b + c
}
const render = closuer();
render();
render = null; // 手动设置为null,GC会自己去清除
- 事件监听未被移除
function addEvent (){
const node = document.getElementById(‘warp’);
node.addEventListener(‘touchmove’,()=>{
console.log(‘In Move’);
})
}
const onTouchEnd = (){
const node = document.getElementById(‘warp’);
node.
}
useEffect(()=>()=>{
const node = document.getElementById(‘warp’);
node.removeEventListener(‘touchmove’);
}) // 类似react 生命周期函数: componentWillUnmount
render(
// code…
)- 缓存。 不管是啥缓存,都需要设置好过期时间。
面试官: 那你能不能说说你是如何排查内存泄露的?
分析一波:到这,回答中规中矩。但面试官的问题真的就到这了吗? 明显不是。 面试官问你是如何排查问题,其实就是再问,你是如何定位到问题的。
也就是说,内存泄露会导致页面卡顿,甚至是页面崩溃。相信你在用APP得开发包或者开发包测试问题的时候,肯定遇到过整个APP闪退的事情,因为在真机器调试的过程中难免会遇见内存不够用的时候。
那么,问题来了。 内存泄露会导致页面卡顿或者崩溃,那页面卡顿就是内存泄露导致的吗? 所以面试官真正想问的是,你是如何发现某个页面有可能发生了内存泄露,并且你是如何诊断该问题是内存泄漏引起的。
我在其它文章里有提过,前端性能优化首先得确立一些性能指标,那内存泄漏不正式性能指标的一种吗?那明确了指标不就是该去获取相关数据,然后上报给性能平台吗?
3.内存泄漏相关性能指标的确立
-
window 对象上新增加的属性数量
-
在加载页面之前
Object.kyes(window)
-
离开页面(路由跳转、页面关闭、后台APP关闭等)之前
Object.kyes(window)
-
一些特殊函数,例如产生闭包的函数变量是否重新赋值为null. 也就是说你写的闭包有被清理掉吗?或者说,
function closuer(){
const a = 0;
return (b)=> a + b
}
API.addClosuer(closuer);
const result = closuer();
API.addClosuer(result);
result = null;
closuer = null;
// 记录页面离开的时间,和被监听的闭包函数有没有被释放。
const list = API.getClosuer(); // 被监听的闭包函数集合,最好的结果就是 {closuer:null,result: null,…}
API.上报(API.getClosuer());
这样,你的性能平台上就能看见这一次上报的数据,页面里什么时候产生了闭包,又是什么时候闭包被清除了,也就一清二楚。
-
事件触发的次数以及事件处理的时间。
-
如果js主线程堵塞了,那当下场景的事件触发也就一定会延迟或者无限等待。 这里用
performance.now
-
performance.now()
方法返回当前网页从performance.timing.navigationStart
到当前时间之间的微秒数,其精度可达100万分之一秒
。 -
performance.now()
近似等于Date.now()
,但前者返回的是毫秒,后者返回的是微秒,后者的精度比前者高1000倍。 -
页面DOM元素数量是否异常。
-
深度优先遍历,获取DOM树的深度。这里可以根据不同场景不同页面来设定DOM树深度的最大阀值。超过最大阀值则平台进行预警。 因为这意味着页面有动态新增DOM的事情发生。
-
FPS,有明显长波段的不平稳。
-
重绘的次数。
最后
为了让大家快速精通JavaScript,在这里免费分享给大家一份Javascript学习指南。
Javascript学习指南文档涵盖了javascript 语言核心、词法结构 、类型、值和变量 、表达式和运算符 、语句、对象 、数组 、函数 、类和模块 、 正则表达式的模式匹配、 javascript的子集和扩展 、服务器端javascript /客户端javascript 、web浏览器中的javascript 、window对象 、脚本化文档、脚本化css 、事件处理等22章知识点。内容丰富又详细,拿下互联网一线公司offfer的小伙伴都在看。
每个知识点都有左侧导航书签页,看的时候十分方便,由于内容较多,下面列举的部分内容和图片。
对象
-
创建对象
-
属性的查询和设置
-
删除属性
-
检测属性
-
枚举属性
-
属性getter和setter
-
属性的特性
数组
-
创建数组
-
数组元素的读和写
-
稀疏数组
-
数组长度
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
![](https://i-blog.csdnimg.cn/blog_migrate/aba17f97a2a0bb64f6768a2fc58654b8.jpeg)
核心竞争力,怎么才能提高呢?
成年人想要改变生活,逆转状态?那就开始学习吧~
万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。
为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。
前端面试题汇总
JavaScript
性能
linux
前端资料汇总
完整版PDF资料免费分享,只需你点赞支持,动动手指点击此处就可领取了。
前端工程师岗位缺口一直很大,符合岗位要求的人越来越少,所以学习前端的小伙伴要注意了,一定要把技能学到扎实,做有含金量的项目,这样在找工作的时候无论遇到什么情况,问题都不会大。
linux**
前端资料汇总
完整版PDF资料免费分享,只需你点赞支持,动动手指点击此处就可领取了。
前端工程师岗位缺口一直很大,符合岗位要求的人越来越少,所以学习前端的小伙伴要注意了,一定要把技能学到扎实,做有含金量的项目,这样在找工作的时候无论遇到什么情况,问题都不会大。