美文网首页饥人谷技术博客
2018-03-20 JS内存简介

2018-03-20 JS内存简介

作者: 彭奕泽 | 来源:发表于2018-03-20 21:15 被阅读7次
内存.png

下面介绍浏览器里js的内存

  1. 除了对象类型,其他基本类型的数据是直接存在stack里

  2. 存对象的时候,将数据存在Heap(堆内存)里,并将数据在Heap中的位置信息存在stack(栈内存)里,由于Heap里存数据不是按顺序存的,所以方便对象随时添加属性。当把对象赋给另一个对象时,就是把这个对象的地址赋给它。
    所以用对象时是引用的对象的地址,这种关系叫引用

  3. 8g的内存相当于 8 * 1024 * 1024 * 1024 * 8 = 6.87E10 bit
    而64位二进制的数相当于 264 = 1.84E19,所以64位二进制能用来存内存里的所有位置

  4. 数字是64位的,字符是16位的(ES3)

5. 面试题

1.引用自身

错误实例:

 var a = {self : a};     //这样a.self会是undefined
 
 上面这样等于
 var a;                  //变量提升,undefined
 a.self = a              //这时a还是是undefined
 赋值时要先确定右边的

正确写法:

 var a = {};
 a.self = a;            //这样a.self就等于它自己这个对象

2

面试2.png
var a = {n:1};
var b = a;
a.x = a = {n:2}   //这一行运行的时候最左的a地址已经确定为最开始的地址,于是先运行a = {n:2},相当于给了a一个新地址,再运行a.x = a,相当于把新地址赋给了旧地址上对象一个x属性

alert(a.x);       // undefined,然而有了新地址的a并没有x属性
alert(b.x);       // [object,Object],b是引用的a的旧地址,所以b有  

3. 垃圾、垃圾回收

var a = function(){};
var a = null;

//a = null后,上面的function没被任何东西引用,变成了垃圾,会被浏览器回收

下面是面试题

var fn = function(){};
document.body.onclick = fn;
fn = null;

请问function是垃圾吗?
答案不是,因为document.body.onclick = fn;还在引用

面试3.png

想要function变成垃圾可写
document.body.onclick = null;
附加:若是把页面关了,就相当于document不存在了,于是这时body、onclick、function都是垃圾,浏览器会把它们回收,但IE6不会把它们当作垃圾,IE6有bug!这就叫内存泄露,垃圾会占满内存,造成卡顿,解决办法:

window.onunload = function(){
    document.body.onclick=  null;
}

相关文章

  • 2018-03-20 JS内存简介

    下面介绍浏览器里js的内存 除了对象类型,其他基本类型的数据是直接存在stack里 存对象的时候,将数据存在Hea...

  • JS内存图

    画JS内存图可以有效的解决JS中的一些内存问题JS中内存分为2中:栈内存(Stack)跟堆内存(Heap)栈内存:...

  • js内存泄露

    js内存泄露 js内存的机制 js的基本变量 boolean string number null undefin...

  • JS 垃圾回收

    内存 JS 数据的存储地址分为栈内存和堆内存。 栈内存 堆内存 在 JS 存放数据的内存中又分为高位和低位,其中高...

  • js知识版图-数据类型

    一、js中内存分为栈内存、堆内存此处引申知识点:js中堆栈内存及函数处理机制 栈内存 从数据类型角度思考 栈内存 ...

  • javascript 内存泄露

    js内存溢出 JS程序的内存溢出后,表现为程序突然卡死或假死或报错 内存生命周期 分配你所需要的内存(变量、函数、...

  • 2018-03-20

    2018-03-20 夏国君 2018-03-20:20:24 · 字数 325 · 阅读 3 · 日记本 201...

  • 2018-03-22

    2018-03-20 静雪恋 2018-03-20 18:28 · 字数 380 · 阅读 0 · 日记本 打卡日...

  • JavaScript数据类型(21)

    JavaScript类型简介 类型转换 各种类型的API 内存图 深拷贝VS浅拷贝 JS的七种数据类型:numbe...

  • Node.js内存管理机制分享

    Node.js内存管理Node.js的一些选项GC研究例子生产环境的设置 1. Node.js如何管理内存 [解惑...

网友评论

    本文标题:2018-03-20 JS内存简介

    本文链接:https://www.haomeiwen.com/subject/bsivqftx.html