javascript中的内存机制
程序员文章站
2022-06-03 22:59:29
...
首先,要知道的是,在程序运行的时候,需要内存来存放数据,而在js中,定义变量时就已经分配好了内存空间,变量的使用只是在内存中读取和写入。
一般来说,系统将内粗分为两种:
1.栈(stack):
有结构,并且每个区块按照一定次序存放,即满足先进后出的原则,存放的是基本的变量和对象的引用,且栈中的数据大小与生存周期都是确定并且明确知道其区块大小的,也因此stack的寻址速度要优于堆内存;
在程序运行时,每个线程分配一个栈,且栈的大小是固定的,如果内部数据大于这个大小,就会产生stack:overflow的报错,一般谷歌浏览器会报
Maximum call stack size exceeded;
2.堆(heap):无结构,数据可以任意存放,用于复杂数据类型的分配空间,如object等;
而在程序运行时,每个进程分配一个堆,可以根据需要不断增加,且堆内存中变量全部被引用完后才会进行回收;
ps(?):为什么null作为object的值会被存储在stack中呢?
var a=new String("1");
var b=new String("1");
console.log(typeof a,typeof b);//object object
console.log(a==b,a===b);//false false 为什么呢??
var time=null;
var data=null;
console.log(typeof time,typeof data);//object object
console.log(time==data,time===data);//true true
对于上面这种情况,我认为情况再于,null被存储在栈内存中,而string被存在堆内存中,两者指针指向不一样;
上一篇: 【蓝桥杯】Python实现蛇行矩阵
下一篇: Python 实现驱动AI机器人