js内存管理系列篇二:内存泄漏,内存管理

简介: 上篇文章讲到 js 内存泄漏存在的各种表现以及问题。现在来说说常见代码中的内存泄漏。

内存泄漏

上篇文章讲到 js 内存泄漏存在的各种表现以及问题。现在来说说常见代码中的内存泄漏。


关于全局变量


 function fn(){
  demo = '我很帅';
 }
  fn();
 function fn2(){
      this.demo2 = 123;
  }
  fn2();

这里就存在两个内存泄漏的问题,fn里的demo = window.demo, 函数自身发生了调用,this 指向全局对象(window)


定时器里存在的内存泄漏问题


有一个这样的业务,如果存在domP这个标签,那么我去获取当前时间赋值上去。同时有一个按钮btn,点击它移除domP,刚开始做了这样一个代码操作

let domP = document.getElementById('domP');
//创建一个定时器
let timeInterval = setInterval(()=>{
     let time = new Date();
     if(domP){
         domP.innerHTML = JSON.stringify(time);
     }
     console.log('time');
 },1000);
 let btn = document.getElementById('btn');
 btn.onclick = ()=>{
     domP.remove();
 }

乍一看是没问题的,但是如果这么写存在的问题是,即使你的domP移除了,它里面的打印事件会一直执行,凡是存在只需要执行一次或几次的定时器操作一定要显示的移除,代码需要这么写

let domP = document.getElementById('domP');        
let timeInterval = setInterval(()=>{
     let time = new Date();
     if(domP){
         domP.innerHTML = JSON.stringify(time);
     }
     console.log('time');
 },1000);
 let btn = document.getElementById('btn');
 btn.onclick = ()=>{
     domP.remove();
     //显示的移除
     clearInterval(timeInterval);
 }


闭包存在的内存泄漏问题



闭包还是用的蛮爽的,但是使用不当也会有内存泄漏问题,比如:

function findGf(){
   this.name = '博主是帅哥';
     this.leg = 160;
 }
 findGf.prototype.selectName = function(){
     let name = this.name;
     return function(){
         return name;
     };
 };
 let gf = new findGf();
 console.log(gf.selectName()());

这里说一下node的一个api,process.memoryUsage,返回一个对象,包含了 Node 进程的内存占用信息。该对象包含四个字段,单位是字节。

在node里执行js文件就可以,命令是 node xxx.js

这四个字段分别是

rss : 总内存占用

heapTotal : 堆占用的内存,包括用到的和没用到的。

heapUsed : 用到的堆内存

external : V8 引擎内部的 C++ 对象占用的内存

这里主要看heapUsed,通过它我们可以实时看到内存的占用多少

1.png

上述代码使用node执行后,内存占用是:

2.png

因为闭包里的name是不会被回收的,一直存在于内存中,那如果试着在闭包里多返回一些数据呢,由于它们常驻内存,所以是不会销毁的,所以用完要及时销毁

function findGf(){
   this.name = '博主是帅哥';
     this.leg = 160;
 }
 findGf.prototype.selectName = function(){
     let name = this.name;
     return function(){
         return name
     };
     //销毁name
     name = null;
 };
 let gf = new findGf();
 console.log(gf.selectName()());


此时的内存占用是:

3.png

heapUsed从584变成了576。

大家可以通过上述的方式去了解下自己写的程序所占的内存,对变量进行一个合理的管理,防止内存泄漏与节省内存;



目录
相关文章
|
22天前
|
监控 JavaScript 算法
如何使用内存监控工具来定位和解决Node.js应用中的性能问题?
总之,利用内存监控工具结合代码分析和业务理解,能够逐步定位和解决 Node.js 应用中的性能问题,提高应用的运行效率和稳定性。需要耐心和细致地进行排查和优化,不断提升应用的性能表现。
172 77
|
22天前
|
监控 JavaScript
选择适合自己的Node.js内存监控工具
选择合适的内存监控工具是优化 Node.js 应用内存使用的重要一步,它可以帮助你更好地了解内存状况,及时发现问题并采取措施,提高应用的性能和稳定性。
114 76
|
22天前
|
监控 JavaScript 数据库连接
解读Node.js内存监控工具生成的报告
需要注意的是,不同的内存监控工具可能会有不同的报告格式和内容,具体的解读方法可能会有所差异。因此,在使用具体工具时,还需要参考其相关的文档和说明,以更好地理解和利用报告中的信息。通过深入解读内存监控报告,我们可以不断优化 Node.js 应用的内存使用,提高其性能和稳定性。
100 74
|
20天前
|
存储 缓存 监控
如何使用内存监控工具来优化 Node.js 应用的性能
需要注意的是,不同的内存监控工具可能具有不同的功能和特点,在使用时需要根据具体工具的要求和操作指南进行正确使用和分析。
63 31
|
16天前
|
存储 监控 算法
Java内存管理深度剖析:从垃圾收集到内存泄漏的全面指南####
本文深入探讨了Java虚拟机(JVM)中的内存管理机制,特别是垃圾收集(GC)的工作原理及其调优策略。不同于传统的摘要概述,本文将通过实际案例分析,揭示内存泄漏的根源与预防措施,为开发者提供实战中的优化建议,旨在帮助读者构建高效、稳定的Java应用。 ####
31 8
|
20天前
|
JavaScript
如何使用内存快照分析工具来分析Node.js应用的内存问题?
需要注意的是,不同的内存快照分析工具可能具有不同的功能和操作方式,在使用时需要根据具体工具的说明和特点进行灵活运用。
39 3
|
24天前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
196 1
|
13天前
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
22天前
|
Java
JVM内存参数
-Xmx[]:堆空间最大内存 -Xms[]:堆空间最小内存,一般设置成跟堆空间最大内存一样的 -Xmn[]:新生代的最大内存 -xx[use 垃圾回收器名称]:指定垃圾回收器 -xss:设置单个线程栈大小 一般设堆空间为最大可用物理地址的百分之80
|
23天前
|
Java
JVM运行时数据区(内存结构)
1)虚拟机栈:每次调用方法都会在虚拟机栈中产生一个栈帧,每个栈帧中都有方法的参数、局部变量、方法出口等信息,方法执行完毕后释放栈帧 (2)本地方法栈:为native修饰的本地方法提供的空间,在HotSpot中与虚拟机合二为一 (3)程序计数器:保存指令执行的地址,方便线程切回后能继续执行代码
19 3