debug_zval_dumpとは? わかりやすく解説

Weblio 辞書 > コンピュータ > PHP関数リファレンス > debug_zval_dumpの意味・解説 

debug_zval_dump

(PHP 4 >= 4.2.0, PHP 5)
debug_zval_dump — 内部的な Zend の値を表す文字列をダンプする

説明

void debug_zval_dump ( mixed variable )
内部的な Zend の値を表す文字列をダンプします。

パラメータ

variable
評価される変数

返り値

値を返しません。

例 2402. debug_zval_dump() の例
<?php
$var1 = 'Hello World';
$var2 = '';

$var2 =& $var1;

debug_zval_dump(&$var1);
?>
上の例の出力は以下となります。

string(11) "Hello World" refcount(3)

    


refcount に注意: この関数によって返される refcount の値は、 特定の状況下では自明ではありません。例えば、とある開発者は上記の例で refcount2 を示すと予想したかも知れません。 実際に debug_zval_dump() がコールされるとき、 3 番目の参照が生成されます。
この動作は、変数が debug_zval_dump() に参照渡しされない場合、よりその度合いを増します。 例えば、上記の例を僅かに修正したバージョンを考えてみます。
例 2403.
<?php
$var1 = 'Hello World';
$var2 = '';

$var2 =& $var1;

debug_zval_dump($var1); // この時、参照で渡されない
?>
上の例の出力は以下となります。

string(11) "Hello World" refcount(1)

     


なぜ refcount(1) でしょうか? なぜなら関数がコールされるとき、 $var1 のコピーが作成されるためです。
この関数は、refcount1 の変数が渡される (コピーもしくは値渡し) とき、より 混乱させます。
例 2404.
<?php
$var1 = 'Hello World';

debug_zval_dump($var1);
?>
上の例の出力は以下となります。

string(11) "Hello World" refcount(2)

     


ここで refcount2 は自明ではありません。特に上記の例を考える場合はそうです。 では、何が起こっているのでしょうか ?
変数が単一の参照 (debug_zval_dump() の引数として使用される前の $var1) を持つ場合、PHP のエンジンは関数に渡される様式を最適化します。内部的に PHP は参照 (refcount がこの関数のスコープのために増加されます) のように $var1 を扱い、参照渡しされた変数に 書き込みが発生するかどうかの警告を伴ってコピーが作成されます。 ただし、書き込みの瞬間だけです。これは "copy on write" として知られます。
そのため、もし debug_zval_dump() がただ一つのパラメータ (もしくはない) に書き込みが発生した場合、コピーが作成されます。 その時までパラメータは参照を保持し、関数呼び出しのスコープに対して refcount2 にインクリメントされる原因になります。

参考

var_dump()
debug_backtrace()
リファレンスの説明
» Reference Counting and Aliasing (Andi Gutmans による)
» リファレンスの説明 (Derick Rethans による)



このページでは「PHP関数リファレンス」からdebug_zval_dumpを検索した結果を表示しています。
Weblioに収録されているすべての辞書からdebug_zval_dumpを検索する場合は、下記のリンクをクリックしてください。
 全ての辞書からdebug_zval_dump を検索

英和和英テキスト翻訳>> Weblio翻訳
英語⇒日本語日本語⇒英語
  

辞書ショートカット

すべての辞書の索引

「debug_zval_dump」の関連用語

debug_zval_dumpのお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



debug_zval_dumpのページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
PHP Documentation GroupPHP Documentation Group
Copyright © 1997 - 2025 by the PHP Documentation Group.

©2025 GRAS Group, Inc.RSS