JavaScriptの定数プールとヒープの違いは何ですか

青灯夜游
リリース: 2022-02-08 14:54:59
オリジナル
2411 人が閲覧しました

JavaScript における定数プールとヒープの違い: 1. 定数プールは定数と基本データ型の保存に使用され、ヒープは複雑なデータ型の保存に使用されます; 2. 定数のシステム効率ヒープは領域とアドレスを割り当てるために、アドレスをスタックに格納する必要があるため、効率はスタック (定数プール) よりも低くなります。

JavaScriptの定数プールとヒープの違いは何ですか

このチュートリアルの動作環境: Windows7 システム、JavaScript バージョン 1.8.5、Dell G3 コンピューター。

JavaScript のメモリはスタックメモリ、ヒープメモリ、定数プールに分かれており、定数プールは一般にスタックにまとめられます。 : 基本データ型の格納に使用されます

  • 定数プール: 定数の基本データ型の格納に使用されます (一般にスタック メモリに分類されます)

  • ヒープ メモリ: 複雑なデータ型を格納するために使用されます

  • 変数が基本データ型を格納する場合、変数の値はスタック メモリに格納されます

    変数が複雑なデータ型を格納する場合データ型、変数値は js によって割り当てられたメモリ アドレスであり、ヒープ メモリ内の複雑なデータ型を指します。
スタック メモリ (定数プール) その特性により、システム効率が比較的高く、高いです。ヒープ メモリは領域とアドレスを割り当て、スタックにアドレスを格納する必要があるため、効率はスタックよりも低くなります。

スタック メモリ

基本的な数値型は占有スペースが少なく、サイズが固定されており、頻繁に使用されるため、スタックに格納されます。 Memory基本データ型の 1 つである数値型 (Number) を例に挙げます。

基本データ型変数を宣言すると、変数名と具体的な値が格納されます。スタック メモリ内

console.log(a) を使用すると、対応する値が出力されます

JavaScriptの定数プールとヒープの違いは何ですか##ヒープ メモリ

##複雑なデータ型は多くのスペースを占有し、サイズが固定されていないため、スタックに保存するとパフォーマンスに影響を与えるため、ヒープ メモリに保存されます

データを格納する変数を宣言する場合 複合データ型を使用する場合、変数名と特定の値がスタックメモリに生成されますが、この特定の値がJSによって割り当てられるメモリ参照アドレスになります。このアドレスは、ヒープ メモリに保存された、作成した複合データ型を指します。変数を呼び出すと、パーサーは変数に対応する参照アドレスに基づいて、対応するオブジェクトを参照します。

変数のコピーJavaScriptの定数プールとヒープの違いは何ですか

基本データ型のコピー:

var num1=5; var num2=num1;
ログイン後にコピー
上記のコードでは、num1 と num2 は実際には2 つの異なる変数、それらの間の操作は互いに関連していません。これは、js では、このタイプの変数コピーは実際には変数のコピー (つまり、num2=1) を生成するためです。図

複合データ型のコピー:

var person={name:'李华'}; //创建一个对象 var per=person ; //进行对象的复制
ログイン後にコピー

基本データ型変数のコピーとは異なり、複合データ型オブジェクトをコピーする場合の本質は次のとおりです。変数のメモリ参照アドレスをコピーするため、person と per の参照アドレスは同じになります。どちらも同じオブジェクトを参照します。person を操作しても per を操作しても、メモリ内の同じオブジェクトを操作することになります。

図に示すように:

JavaScriptの定数プールとヒープの違いは何ですか

#関数パラメータの受け渡しは、実際には一種の変数コピーです

#
var x=1; function fun (x){ var y=x+1; }
ログイン後にコピー

[関連する推奨事項:

JavaScript 学習チュートリアル

JavaScriptの定数プールとヒープの違いは何ですか]

以上がJavaScriptの定数プールとヒープの違いは何ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!