当前位置:首页 » 《资源分享》 » 正文

哪些操作会造成内存泄漏以及如何解决内存泄漏_萌萌的博客

20 人参与  2022年01月07日 11:26  分类 : 《资源分享》  评论

点击全文阅读


内存泄漏

    • 内存泄漏含义:
    • 1.造成内存泄漏的情况
      • 1.1
      • 1.2
      • 1.3
    • 2.解决内存泄漏的方式
      • 2.1global variables:
      • 2.2使用timers或者callbacks
      • 2.3 闭包可以访问外部(封闭)函数变量的内部函数
      • 2.4DOM引用

内存泄漏含义:

内存泄漏指任何对象在不再拥有或需要它之后任然存在

1.造成内存泄漏的情况

1.1

垃圾回收器定期扫描对象,并计算引用了每个对象的其他对象的数量。如果一个对象的引用数量为0(没有其他对象引用过该对象)或对该对象的唯一引用是循环的,那么该对象的内存即可回收

1.2

setTimeout的第一个参数使用字符串而非函数的话,会引发内存泄漏

1.3

闭包、控制台日志、循环(在两个对象彼此引用且彼此保留时,就会产生一个循环)

2.解决内存泄漏的方式

2.1global variables:

对未声明的变量的引用在全局对象内创建一个新变量,在浏览器中,全局对象就是window

function foo(arg){
 var='some text'  //等同于window.var ='some text'
}

解决:创建意外的全局变量

function foo(){
 this.var='potential accident'
}
  • 可以在js文件开头添加 ’ use strict’ ,使用严格模式。这样在严格模式下解析js可以防止意外的全局变量
  • 在使用完之后,对其赋值为null或者重新分配

2.2使用timers或者callbacks

在js中使用setInterval非常常见
大多数库都会提供观察者或者其它工具来处理回调函数,在他们自己的实例变为不可达时,会让回调函数也变为不可达,对于setInterval,下面这样的代码非常常见

var servarData=loadData()
setInterval(function(){
 var render =document.getElementById('render')
 if(render){
  render.innerHTML=JSON.stringify(serverData)
 }
},5000)

这个例子阐述着timers可能发生的情况:计时器会引用不再需要的节点或数据

2.3 闭包可以访问外部(封闭)函数变量的内部函数

js开发的一个关键方面就是闭包:一个可以访问(封闭)函数变量的内部函数。

var theThing=null
var replaceThing=function(){
 var  originalThing=theThing
 var unused=function(){
  if(originalThing) console.log('hi')
  theThing={
   longStr:new Array(1000000).join('*'),
   someMethod:function(){
     console.log('message')
    }
  }
 }
}
setInterval(replaceThing,1000)

2.4DOM引用

有时候,在数据结构中存储DOM结构是有用的,假设要快速更新表中的几行内容,将每行DOM的引用存储在字典或数组中可能是有意义的,当这种情况发生时,就会保留同一DOM元素的两份引用:一个在DOM树中,另一个在字典中,如果将来某个时候你决定要删除这些行,则需要让两个引用都不可达

  var elements ={
  button:document.getElementById('button'),
  image:document.getElementById('image')
  }
  function doStuff(){
    elements.image.src='http://example.com/image_name.png'
  }
  function removeImage(){
    document.body.removeChild(document.getElementById('image'))
  }

点击全文阅读


本文链接:http://m.zhangshiyu.com/post/32847.html

泄漏  对象  引用  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 远山长天青晓免费在线(乔意林景辞秦艺晚)_远山长天青晓免费在线
  • 老婆骂我废物,却又求我爱她小说免费试读_「秋芙然姜言铭言铭哥」小说精彩节选推荐
  • 完结文余留空念与微风最后结局列表_完结文余留空念与微风最后结局(傅时砚许初玖)
  • 全文此去经年人未还+后续+番外(沈青禾贺临渊)列表_全文此去经年人未还+后续+番外
  • [冷战两个月后,我选择跳楼回家]最新后续章节在线阅读_柳依依宋青雪儿人物羁绊章节精选
  • 女儿有钱后却转身起诉苦命妈妈全列表_女儿有钱后却转身起诉苦命妈妈全(陈雨晴林淑芬)
  • 带女儿离婚后,偏爱白月光的父子俩后悔了章节限时抢先看‌_凤遥免费试读
  • 女儿有钱后却转身起诉苦命妈妈(陈雨晴林淑芬)全书浏览_女儿有钱后却转身起诉苦命妈妈全书浏览
  • 完结文远山长天青晓+后续+结局列表_完结文远山长天青晓+后续+结局(乔意林景辞秦艺晚)
  • 此去经年人未还全书+后续(沈青禾霍沉洲)列表_此去经年人未还全书+后续(沈青禾霍沉洲)此去经年人未还全书+后续在线
  • 桃花依然笑春风全书+后续+结局(陆乘渊云梵音)列表_桃花依然笑春风(陆乘渊云梵音)桃花依然笑春风全书+后续+结局在线
  • 经年离歌愁未休,顾允廷宋卿落结局+番外完结完本_完本经年离歌愁未休,顾允廷宋卿落结局+番外完结

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1