phpにおけるglobalと$GLOBALS[""]の違い 当初、globalと$GLOBALSは書き方が違うだけで同じだと思っていましたが、実際に使ってみると、両者にはまだ大きな違いがあることが分かりました。大きい!
まず以下の例を見てください:
PHPコード
// 例 1
関数 test_global() {
グローバル $var1、$var2;
$var2 =& $var1;
}
関数 test_globals() {
$GLOBALS['var3'] =& $GLOBALS['var1'];
}
$var1 = 5;
$var2 = $var3 = 0;
test_global();
$var2 ."n";
を出力します
Test_globals();
$var3 ."n";
を出力します
?>
充実効果は次のとおりです:
0
5
これは 5 が 2 つあるはずがありませんか?
それでは、上記の質問を保存して、$GLOBALS とグローバルの原理を詳しく分析してみましょう
変数が実際にはコード内の対応する物理メモリの「コード名」であることは誰もが知っています
PHPマニュアルの$GLOBALSの説明を引用:
グローバル変数: $GLOBALS
注: $GLOBALS は PHP 3.0.0 以降で使用できます。
定義されたすべてのグローバル変数で構成される配列。変数名は配列のインデックスです。
これは「スーパーグローバル」、またはアクティブなグローバル変数として説明できます。
つまり、上記のコードの $var1 と $GLOBALS['var1'] は、2 つの異なる変数ではなく、同じ変数を参照しています。
グローバルが何をするのか分析してみましょう?
PHP の関数によって生成された変数は関数のプライベート変数であることは誰もが知っていますが、グローバルによって生成された変数はこの規則を回避できないのはなぜでしょうか。次のコードを見てください。
PHPコード
グローバル $a;
unset($a);
}
$a = 1;
テスト();
$a を印刷します;
?>
充実効果は次のとおりです:
1
なぜ1が出力されるのでしょうか? $aの設定が解除されていませんか?設定解除に失敗しましたか? PHPのバグ?
つまり、globalはテスト関数の外側の$aと区別するために、テスト関数の外側の$aに対してエイリアス変数「$a」を生成します
上記の例 1 に戻り、test_global のコード「$var2 =& $var1;」を見てください。つまり、$var2 は var1 が指す物理メモリ アドレスを指します。
global は、関数の実際の外部変数ではなく、関数の外部変数を指すエイリアス変数を関数内に生成します。エイリアス変数が指すアドレスが変更されると、例のような予期しない状況が発生します。 1.
$GLOBALS[] は確かに外部変数と呼ばれ、関数内外で常に一貫性を保ちます。
次の 2 つの例を比較できます:
グローバル:
関数 myfunction(){
グローバル $bar;
unset($bar);
}
$bar="何か";
myfunction();
エコー $bar;
?>
出力: 何か
関数 foo() {
unset($GLOBALS['bar']);
}
$bar = "何か";
foo();
?>
出力: 空
グローバルの適用例
$a = 1;
$b = $a + $b;
}
合計();
エコー $b;
上記のスクリプトの出力は「3」になります。グローバル変数 $a と $b は関数内で宣言されており、任意の変数のすべての参照変数はグローバル変数を指します