首页 web前端 js教程 理解Javascript_01_理解内存分配原理分析_javascript技巧

理解Javascript_01_理解内存分配原理分析_javascript技巧

May 16, 2016 pm 06:18 PM
内存分配

原始值和引用值
在ECMAScript中,变量可以存放两种类型的值,即原始值和引用值。
原始值指的就是代表原始数据类型(基本数据类型)的值,即Undefined,Null,Number,String,Boolean类型所表示的值。
引用值指的就是复合数据类型的值,即Object,Function,Array,以及自定义对象,等等

栈和堆
与原始值与引用值对应存在两种结构的内存即栈和堆
栈是一种后进先出的数据结构,在javascript中可以通过Array来模拟栈的行为
复制代码 代码如下:

var arr = []; //创建一个栈
arr.push("apple");//压入元素"apple" ["apple"]
arr.push("orange");//压入元素"orange" ["apple","orange"]
arr.pop();//弹出"orange" ["apple"]
arr.push("banana");//压入元素"banana" ["apple","banana"]

我们来看一下,与之对应的内存图:
理解Javascript_01_理解内存分配原理分析_javascript技巧
原始值是存储在栈中的简单数据段,也就是说,他们的值直接存储在变量访问的位置。
堆是存放数据的基于散列算法的数据结构,在javascript中,引用值是存放在堆中的。
引用值是存储在堆中的对象,也就是说,存储在变量处的值(即指向对象的变量,存储在栈中)是一个指针,指向存储在堆中的实际对象.
例:var obj = new Object(); obj存储在栈中它指向于new Object()这个对象,而new Object()是存放在堆中的。
那为什么引用值要放在堆中,而原始值要放在栈中,不都是在内存中吗,为什么不放在一起呢?那接下来,让我们来探索问题的答案!
首先,我们来看一下代码:
复制代码 代码如下:

function Person(id,name,age){
this.id = id;
this.name = name;
this.age = age;
}
var num = 10;
var bol = true;
var str = "abc";
var obj = new Object();
var arr = ['a','b','c'];
var person = new Person(100,"jxl",22);

然后我们来看一下内存分析图:
理解Javascript_01_理解内存分配原理分析_javascript技巧
变量num,bol,str为基本数据类型,它们的值,直接存放在栈中,obj,person,arr为复合数据类型,他们的引用变量存储在栈中,指向于存储在堆中的实际对象。

由上图可知,我们无法直接操纵堆中的数据,也就是说我们无法直接操纵对象,但我们可以通过栈中对对象的引用来操作对象,就像我们通过遥控机操作电视机一样,区别在于这个电视机本身并没有控制按钮。


现在让我们来回答为什么引用值要放在堆中,而原始值要放在栈中的问题:

记住一句话:能量是守衡的,无非是时间换空间,空间换时间的问题

堆比栈大,栈比堆的运算速度快,对象是一个复杂的结构,并且可以自由扩展,如:数组可以无限扩充,对象可以自由添加属性。将他们放在堆中是为了不影响栈的效率。而是通过引用的方式查找到堆中的实际对象再进行操作。相对于简单数据类型而言,简单数据类型就比较稳定,并且它只占据很小的内存。不将简单数据类型放在堆是因为通过引用到堆中查找实际对象是要花费时间的,而这个综合成本远大于直接从栈中取得实际值的成本。所以简单数据类型的值直接存放在栈中。

总结:

程序很简单,但它是一切的根本,基础是最重要的,因为摩天大厦也是一块砖一块瓦的搭建起来的。
内存是程序执行的根本,搞懂了内存,就等于搞懂了一切。
心血之作,鼓励一下自已,加油!

参考:
JavaScript高级程序设计
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1671
14
CakePHP 教程
1428
52
Laravel 教程
1331
25
PHP教程
1276
29
C# 教程
1256
24
Java 函数中内存分配的最佳实践是什么? Java 函数中内存分配的最佳实践是什么? May 02, 2024 pm 10:33 PM

Java函数中内存分配的最佳实践包括:使用自动内存管理,确保使用适当的GC算法。监控内存分配模式,识别内存泄漏或瓶颈。使用对象池重用相似大小的对象。避免大量短生命周期分配,考虑使用替代方法。使用空对象模式避免创建不需要的对象。明确释放本机资源,确保释放JavaGC无法访问的内存。

golang函数的内存分配分析 golang函数的内存分配分析 Apr 29, 2024 pm 02:24 PM

问题:如何分析Go函数的内存分配?答案:使用pprof包中的heapprofile函数生成堆转储。分析堆转储以确定分配的类型和大小。详细说明:生成堆转储:启用heap剖析器并调用heapprofile函数。分析堆转储:使用gotoolpprof命令分析堆转储文件,以查看分配信息。

深入探讨Golang切片的内存分配和扩容策略 深入探讨Golang切片的内存分配和扩容策略 Jan 24, 2024 am 10:46 AM

Golang切片原理深入剖析:内存分配与扩容策略引言:切片是Golang中常用的数据类型之一,它提供了便捷的方式来操作连续的数据序列。在使用切片的过程中,了解其内部的内存分配与扩容策略对于提高程序的性能十分重要。在本文中,我们将深入剖析Golang切片的原理,并配以具体的代码示例。一、切片的内存结构和基本原理在Golang中,切片是对底层数组的一种引用类型,

分析Java中堆和栈的不同以及它们的应用情景 分析Java中堆和栈的不同以及它们的应用情景 Feb 24, 2024 pm 11:12 PM

Java堆和栈的区别及应用场景解析,需要具体代码示例在Java程序中,堆和栈是两个常用的数据结构,它们在内存中承担不同的角色和功能。了解堆和栈的区别对于编写高效的Java程序至关重要。首先,我们来看一下Java堆。堆是一个用来存储对象的区域,所有在程序中被创建的对象都被存储在堆中。堆是在程序运行时动态分配和释放内存的地方,它不受任何限制,并且可以根据需要自动

C++ 函数内存分配的常见错误及其解决方法 C++ 函数内存分配的常见错误及其解决方法 Apr 22, 2024 pm 05:09 PM

函数内存分配的常见错误包括:1)裸指针悬垂;2)内存泄漏;3)野指针;4)释放无效指针。解决方法:1)使用智能指针;2)使用RAII;3)使用内存池。

C++ 函数的内存分配和销毁中的陷阱和最佳实践 C++ 函数的内存分配和销毁中的陷阱和最佳实践 Apr 23, 2024 am 09:36 AM

在C++中,函数分配和销毁内存时需要注意陷阱,包括内存泄漏(持有已不需要的内存指针)和悬空指针(指向已释放内存)。为了防止这些问题,最佳实践包括:使用智能指针(如std::shared_ptr)自动管理内存;采用RAII技术确保对象超出范围时释放资源;避免返回局部变量的指针;仔细处理析构函数以释放分配的内存。通过遵循这些实践,可以确保代码的可靠性和防止内存泄漏和悬空指针。

Golang函数的内存分配与回收方法 Golang函数的内存分配与回收方法 May 16, 2023 pm 01:51 PM

Golang是一种面向对象的编程语言,自带垃圾回收机制,因此内存分配和回收相较其他语言更加容易。在Golang中,函数也是可以分配内存和回收内存的,本文将对Golang函数的内存分配与回收方法进行详细介绍。一、函数的内存分配当函数被声明时,程序会为其分配一段内存用于存储这个函数的代码和静态变量。当函数被调用时,程序会为其分配一块栈内存用于存储该次调用的局部变

C++内存优化秘籍:减少内存占用的关键方法 C++内存优化秘籍:减少内存占用的关键方法 Nov 27, 2023 am 08:29 AM

C++内存优化秘籍:减少内存占用的关键方法背景:在C++开发过程中,内存优化是一个非常重要的主题。随着软件的功能越来越复杂和庞大,程序的内存占用也会相应增加。过高的内存占用不仅会影响程序的性能,还可能导致内存溢出等严重问题。为了提高程序的效率和稳定性,减少内存消耗是必不可少的。文章概述:本文将介绍一些减少C++程序内存占用的关键方法。这些方法包括:合理使用数

See all articles