Maison  >  Article  >  développement back-end  >  Types de données de base de JavaScript

Types de données de base de JavaScript

php中世界最好的语言
php中世界最好的语言original
2018-03-06 13:27:561149parcourir

JavaScript est un langage de script littéral. Il s'agit d'un langage basé sur un prototype à typage dynamique, faiblement typé, avec prise en charge intégrée des types. Par conséquent, JavaScript est un point de connaissance très basique.Cet article présente principalement comment les types de données de base et les types de données de référence sont stockés dans JavaScript. Les amis qui en ont besoin peuvent s'y référer.

Structure de données de base

Stack

Stack, un tableau linéaire qui permet uniquement les opérations d'insertion ou de suppression dans une section, est une structure de données premier entré, dernier sorti.

Heap

Heap est une structure de données basée sur un algorithme de hachage.

File d'attente

La file d'attente est une structure de données premier entré, premier sorti (FIFO).

Stockage des types de données en JavaScript

Les types de données en JavaScript sont divisés en types de données de base et en types de données de référence. Une différence entre eux est le stockage. l'emplacement est différent.

Types de données de base

Nous savons tous que les types de données de base en JavaScript sont :

  • Chaîne

  • Nombre

  • Booléen

  • Non défini

  • Null

  • Symbole (ignorer pour l'instant)

Les types de données de base sont de simples segments de données, qui sont stockés dans la mémoire de la pile.

Types de données de référence

Les types de données de référence en JavaScript sont :

  • Array

  • Objet

Le type de données de référence est stocké dans la mémoire tas, puis une référence à l'objet réel dans la mémoire tas est stockée dans la mémoire pile. Par conséquent, les opérations sur les types de données de référence en JavaScript opèrent sur des références à des objets plutôt que sur des objets réels.

On peut comprendre qu'une adresse est stockée dans la mémoire de la pile, et cette adresse est liée à la valeur réelle dans la mémoire du tas.

Illustration

Maintenant, essayons de déclarer quelques variables :

var name="axuebin";
var age=25;
var job;
var arr=[1,2,3];
var obj={age:25};

La figure suivante peut être utilisée pour représenter le type de données en mémoire . Situation de stockage :

À ce stade, les trois types de données de base name, age et job sont directement stockés dans la mémoire de la pile, tandis que arr et obj sont dans la pile. Il n'y a qu'une adresse stockée dans la mémoire pour représenter une référence à la mémoire tas.

Copier

Types de données de base

Pour les types de données de base, si vous copiez, le système créera automatiquement de nouvelles variables L'allocation d'une nouvelle valeur dans la mémoire de la pile est facile à comprendre.

Types de données de référence

Pour les types de données de référence tels que les tableaux et les objets, il y aura des différences lors de la copie :

Le système attribuera également automatiquement une valeur dans la mémoire de pile pour la nouvelle variable, mais cette valeur n'est qu'une adresse. En d’autres termes, la variable copiée a la même valeur d’adresse que la variable d’origine et pointe vers le même objet dans la mémoire tas.

Si comme indiqué, après avoir exécuté var objCopy=obj, obj et objCopy ont la même valeur d'adresse et exécutent le même objet réel dans la mémoire du tas.

Quelle différence cela fait-il ?

Lorsque je modifie obj ou objCopy, cela entraînera le changement d'une autre variable.

Pourquoi ?

Pourquoi les types de données de base existent-ils sur la pile, alors que les types de données de référence existent sur le tas ?

  1. Le tas est plus grand que la pile et la comparaison de la pile est plus rapide.

  2. Le type de données de base est relativement stable et occupe relativement peu de mémoire.

  3. La taille du type de données de référence est dynamique et illimitée.

  4. La mémoire tas est un stockage non ordonné et peut être obtenue directement sur la base de références.

Article de référence

Comprendre l'allocation de mémoire js

Valeur originale et valeur de référence

Dans ECMAScript, les variables peuvent stocker deux types de valeurs, à savoir les valeurs primitives et les valeurs de référence.
Les valeurs primitives font référence à des valeurs représentant des types de données primitifs (types de données de base), c'est-à-dire des valeurs représentées par les types Undefined, Null, Number, String et Boolean.
Les valeurs de référence font référence aux valeurs des types de données composites, à savoir Objet, Fonction, Tableau et objets personnalisés, etc.

Pile et tas

Il existe deux structures de mémoire correspondant à la valeur d'origine et à la valeur de référence, à savoir la pile et le tas
La pile est une structure de données dernier entré, premier sorti. En JavaScript, le comportement du. la pile peut être simulée via Array

Les valeurs primitives sont de simples données stockées sur la pile, c'est-à-dire que leurs valeurs sont stockées directement aux emplacements accessibles par les variables.

Heap est une structure de données basée sur un algorithme de hachage. En JavaScript, les valeurs de référence sont stockées dans le tas.
La valeur de référence est l'objet stocké dans le tas, c'est-à-dire que la valeur stockée au niveau de la variable (c'est-à-dire la variable pointant vers l'objet, stockée dans la pile) est un pointeur pointant vers l'objet réel stocké dans le tas.

例: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,"笨蛋的座右铭",25);

然后我们来看一下内存分析图:

变量num,bol,str为基本数据类型,它们的值,直接存放在栈中,obj,person,arr为复合数据类型,他们的引用变量存储在栈中,指向于存储在堆中的实际对象。

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

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

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

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

相关推荐:

JavaScript事件处理机制解析

javascript模块加载器详细说明

JavaScript关于图片处理与合成的方法详解

 

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn