内存泄漏和内存溢出JavaScript之深入浅出理解内存泄漏和内存溢出

Posted ✎﹏ℳ๓敬坤

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了内存泄漏和内存溢出JavaScript之深入浅出理解内存泄漏和内存溢出相关的知识,希望对你有一定的参考价值。

📒 博客首页:✎﹏ℳ๓敬坤的博客 🎈
😊 我只是一个代码的搬运工 🎃
🎉 欢迎来访的读者关注、点赞和收藏 🤞
😉 有问题可以私信交流 😆
📃 文章标题:javascript之深入浅出理解内存泄漏和内存溢出 🖍

内存泄漏和内存溢出

了解内存泄露和内存溢出之前,我们得知道什么是内存!下面就会详细讲解什么内存

什么是内存

内存(Memory)是计算机的重要部件之一,也称内存储器和主存储器,它用于暂时存放CPU中的运算数据,与硬盘等外部存储器交换的数据。它是外存与CPU进行沟通的桥梁,计算机中所有程序的运行都在内存中进行,内存性能的强弱影响计算机整体发挥的水平。只要计算机开始运行,操作系统就会把需要运算的数据从内存调到CPU中进行运算,当运算完成,CPU将结果传送出来。

内存的运行也决定计算机整体运行快慢的程度

内存条由内存芯片、电路板、金手指等部分组成

在项目中我们打开任务管理器=>性能,这里就有我们内存的使用情况

内存泄漏和内存溢出

内存是用于暂时存放CPU中的运算数据,与硬盘等外部存储器交换的数据。既然是用来存储数据那么就会出现内存泄漏和内存溢出的情况!可能大家会觉得泄漏和溢出不是一样的吗🤣接下来就会详细讲解什么是内存泄漏,什么是内存溢出,以及他们的区别

内存溢出

内存溢出(out of memory):一种程序运行出现的错误。当程序运行需要的内存超过剩余的内存时,就会抛出内存溢出的错误。当我们定义一个变量时,程序会给他对应的内存。当然程序分配的内存是由极限的,当我们不停为变量不停的不停的给它添加数据,就会超出这个极限。于是程序就会崩溃,我们称这个过程到结果叫内存溢出

如下,我们有一个杯子,里面有一些水,我们一直往杯子里倒水,会出现什么情况呢🤔没错,会出现水会从杯子里面溢出来,如下下图一样。当我们做出把水倒出杯子,被家长看到,家长就会告诉你们这是错误的行为,严重的可能还会打你一顿。



上面举了一个例子,下面上代码,让我们看看什么是内存溢出吧🧐

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style type="text/css">
			
		</style>
	</head>
	<body>
		你好
		<script type="text/javascript">
			var obj=[]
		</script>
	</body>
</html>

这是我们定义了变量obj,给obj分配了空间,obj并没有数据,这个时候我们运行代码是正常的,如下:

当我们疯狂的obj添加数据,如下:

for(let i=0;i<10000;i++)
	obj.push(new Array(1000000))

这个时候页面就崩溃了,变成下面这样子了

这就是内存溢出导致我们的程序报错,崩溃了!

内存泄漏

内存泄漏:占用的内存没有及时释放,内存泄漏积累得多了就会导致容易内存溢出。当我们定义一个全局变量时,系统就会给这个变量分配内存,然而这个变量,一直占用了一个块地方,没有让出地盘,这种情况我们称它为内存泄漏

如下这是我们平时的内存4.3G:

接下来,看一下我们使用了全局变量没有释放资源会怎么样🤔
代码如下:

window.abc=10
console.log(window.abc)

如下,我们清晰的看到内存比刚刚多了0.3G,这就是内存泄漏

我们在看看释放资源会发生什么呢🤔

window.abc=null

过了一会内存又变少了要变回平时的样子

到了这里就可以总结一下了,内存溢出和内存泄露的区别了

总结

内存泄漏指的是占用的内存没有及时的释放

内存溢出指的是需要的内存超过剩余的内存

内存泄漏不一定会内存溢出,但是内存泄漏过多就会造成内存溢出

以上是关于内存泄漏和内存溢出JavaScript之深入浅出理解内存泄漏和内存溢出的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript如何工作 3之 内存管理+如何处理4个常见的内存泄漏

JVM之内存泄漏和内存溢出

JVM之内存泄漏和内存溢出

JVM系列之六:内存溢出内存泄漏 和 栈溢出

Android面试题之内存溢出和内存泄漏的问题

JavaScript中的内存泄漏以及如何处理