jsの変数、スコープ、メモリを詳しく解説_基礎知識
May 16, 2016 pm 04:35 PM基本的な型の値には、未定義、NUll、Boolean、Number、String が含まれます。これらの型はメモリ内の固定サイズの領域を占有し、値によってアクセスします。
(1) 値の型: 数値、ブール値、null、未定義。
(2) 参照型: オブジェクト、配列、関数。
割り当てられた値が参照型の場合、ヒープ メモリ内でこの値用の領域を割り当てる必要があります。このような値のサイズは固定されていないため (オブジェクトには多くのプロパティとメソッドがあります)、スタック メモリに保存できません。ただし、メモリアドレスのサイズは固定されているため、メモリアドレスをスタックメモリに保存できます。
1 2 3 4 5 6 |
|
つまり、ヒープメモリには参照値が格納され、スタックメモリには固定型の値が格納されます。
1 2 3 4 5 6 7 8 |
|
変数値をコピー
次の例を見てください:
1 2 3 4 5 6 7 8 9 |
|
上記のことから、変数のコピーに関しては、基本型と参照型も異なります。基本型は値そのものをコピーするのに対し、参照型はアドレスをコピーします。
パラメータを渡す
ECMAScript では、すべての関数パラメーターは値によって渡されます。
1 2 3 4 5 6 7 8 9 10 11 |
|
JavaScript は参照渡しではありません。参照渡しがある場合、関数内の変数はグローバル変数となり、外部からアクセスすることもできます。しかし、これは明らかに不可能です。
実行環境と範囲
実行環境は、JavaScript の最も重要な概念の 1 つであり、変数または関数が他のデータにアクセスするための権限を定義します。
グローバル実行環境は、Web ブラウザーではウィンドウ オブジェクトであるため、グローバル変数の関数はすべてウィンドウのプロパティとメソッドとして作成されます。
1 2 3 4 5 6 7 8 9 |
|
実行環境内のコードが実行されると、環境は破棄され、その環境に保存されている変数や関数も破棄されます。グローバル環境の場合は、すべてのプログラムが実行されるか、実行環境が完了するまで破棄されません。ウェブページが完成しました。
var のローカル変数を削除します
1 2 3 4 5 6 7 8 9 |
|
パラメータを渡すことでローカル変数にもなります
1 2 3 4 5 6 7 8 9 |
|
関数本体にも関数が含まれています。この関数のみが関数の内部層にアクセスできます。
1 2 3 4 5 6 7 8 9 |
|
次の方法でアクセスできます:
1 2 3 4 5 6 7 8 9 10 |
|
別のスコープの例:
1 2 3 4 5 6 7 8 9 10 |
|
環境内でコードが実行されると、スコープ チェーンと呼ばれるものが形成されます。その目的は、実行環境内でアクセス権を持つ変数や関数に確実にアクセスできるようにすることです (アクセスするためのルール階層を指します)。 、スコープ チェーンのフロント エンドは、実行環境の変数オブジェクトです。
範囲
関数内で宣言されていないか、var なしで宣言されている変数はグローバル変数です。ウィンドウ オブジェクトのすべてのプロパティは、コード内のどこからでもアクセスできます。変数はローカル変数であり、関数本体内でのみ使用できます。関数のパラメーターは var を使用しませんが、それでもローカル変数です。
ブロック範囲なし
ブロックスコープなし
1 2 3 4 5 6 7 8 9 |
|
for ループ文についても同様です。
変数のクエリ
変数クエリでは、ローカル変数へのアクセスはグローバル変数よりも高速であるため、スコープ チェーンを検索する必要はありません。
以下の例:
1 2 3 4 5 6 7 8 |
|
メモリの問題
JavaScript には自動ガベージ コレクション メカニズムがあり、データが使用されなくなったら、「null」に設定して参照を解放できます。
循環参照
非常に単純な例: DOM オブジェクトは Javascript オブジェクトによって参照され、同時に同じまたは別の Javascript オブジェクトを参照します。この DOM オブジェクトはメモリ リークを引き起こす可能性があります。この DOM オブジェクトへの参照は、スクリプトの停止時にガベージ コレクターによって再利用されません。参照サイクルを中断するには、DOM 要素を参照するオブジェクトまたは DOM オブジェクトへの参照に null を割り当てる必要があります。
閉店
クロージャの外にある変数がクロージャに導入された場合、クロージャの終了時にオブジェクトをガベージコレクション(GC)することはできません。
1 2 3 4 5 6 |
|
DOM リーク
元の COM が削除されると、子ノード参照は削除されない限り再利用できません。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
タイマーが漏洩しました
タイマーもメモリ リークが発生する一般的な場所です。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
デバッグメモリ
Chrome の組み込みメモリ デバッグ ツールを使用すると、メモリ使用量とメモリ リークを簡単にチェックできます:
タイムラインのレコードをクリックします ->

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











大規模なメモリの最適化。コンピュータが 16g/32g のメモリ速度にアップグレードしても変化がない場合はどうすればよいですか?

Lexar が Ares Wings of War DDR5 7600 16GB x2 メモリ キットを発売: Hynix A-die パーティクル、1,299 人民元

関係者によると、サムスン電子とSKハイニックスは2026年以降に積層型モバイルメモリを商品化する予定

Kingbang が新しい DDR5 8600 メモリを発売、CAMM2、LPCAMM2、および通常のモデルから選択可能
