関数・クラス解説

debug_zval_dump

version:PHP 4 >= 4.2.0, PHP 5, PHP 7 (公式)

内部的な Zend の値を表す文字列をダンプする

公式リファレンス

書式

debug_zval_dump ( mixed $variable , mixed ...$variables ) : void

説明

内部的な Zend の値を表す文字列をダンプします。

パラメータ

variable
ダンプする変数。
variables
ダンプする追加の変数。

返値

値を返しません。

サンプル

例1 debug_zval_dump() の例

$var1 = 'Hello World'; $var2 = ''; $var2 =& $var1; debug_zval_dump(&$var1);

上の例の出力は以下となります。

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

注意: refcount に注意

この関数によって返される refcount の値は、 特定の状況下では自明ではありません。例えば、とある開発者は上記の例で refcount は 2 を示すと予想したかも知れません。 実際に debug_zval_dump() がコールされるとき、 3 番目の参照が生成されます。

この動作は、変数が debug_zval_dump() に参照渡しされない場合、よりその度合いを増します。 例えば、上記の例を僅かに修正したバージョンを考えてみます。

$var1 = 'Hello World'; $var2 = ''; $var2 =& $var1; debug_zval_dump($var1); // この時、参照で渡されない

上の例の出力は以下となります。

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

なぜ refcount(1) でしょうか? なぜなら関数がコールされるとき、 $var1 のコピーが作成されるためです。

この関数は、refcount が 1 の変数が渡される (コピーもしくは値渡し) とき、より まぎらわしくなります。

$var1 = 'Hello World'; debug_zval_dump($var1);

上の例の出力は以下となります。

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

ここで refcount の 2 は自明ではありません。特に上記の例を考える場合はそうです。 では、何が起こっているのでしょうか ?

debug_zval_dump() の引数として使用される前の $var1 のように、 変数に単一の参照がある場合、PHP のエンジンは関数に渡される方法を最適化します。 内部的に、PHP は $var1 を参照のように扱います (この関数のスコープによって refcount が増加されます)。 ただし、渡された参照がたまたま書き込まれる場合は注意が必要です。 書き込みの時点でのみコピーが作成されます。これは "copy on write" として知られます。

そのため、もし debug_zval_dump() がたまたま その単一の(および、そうではない)パラメータに書き込みをおこなった場合、コピーが作成されます。 その時までパラメータは参照のままであるため、関数呼び出しのスコープによって refcount が 2 にインクリメントされる原因になります。

参考

  • var_dump() - 変数に関する情報をダンプする
  • debug_backtrace() - バックトレースを生成する
  • リファレンスの説明
  • » リファレンスの説明 (Derick Rethans による)
  • ワード検索


    ※入力キーワードが、関数名・説明文・タグに含まれるものを検索

    関数名アルファベット別

    A B C D E F G H I J
    K L M N O P Q R S T
    U V W X Y Z _

    最終更新一覧

    stristr
     大文字小文字を区別せず文字列を検索し、ヒット箇所以降(あるいは以前)の文字列を返却

    stripslashes
     バックスラッシュでエスケープされた文字列から、バックスラッシュを取り除く

    stripos
     大文字小文字を区別せずに文字列が最初に現れる位置を取得する

    stripcslashes
     addcslashes() でクォートされた文字列をアンクォートする

    strip_tags
     文字列から HTML と PHP のタグを除去して返却

    strcspn
     指定した文字が最初に現れる位置を調べる

    strcoll
     ロケールに基づいて2つの文字列を比較し同じか(あるいは大小)を判定する

    strcmp
     2つの文字列を比較し同じか(あるいは大小)を判定する

    strchr
     strstr() のエイリアス

    strcasecmp
     2つの文字列を比較(大文字小文字を区別せず同じとみなす)

    カテゴリー一覧

    PHP の振る舞いの変更
    音声フォーマットの操作
    認証サービス
    コマンドライン関連
    圧縮およびアーカイブ
    暗号
    データベース関連
    日付および時刻関連
    ファイルシステム
    自然言語および文字エンコーディング
    画像処理および作成
    メール関連
    数学
    テキスト以外の MIME 型
    プロセス制御
    その他の基本モジュール
    その他のサービス
    検索エンジン用の拡張モジュール
    サーバー固有のモジュール
    セッション関連
    テキスト処理
    変数・データ型関連
    ウェブサービス
    Windows 用のモジュール
    XML 操作
    GUI用の拡張モジュール