ホームページ >バックエンド開発 >PHPチュートリアル >PHPのデバッグにおけるvar_export、print_r、var_dumpの違いについて

PHPのデバッグにおけるvar_export、print_r、var_dumpの違いについて

不言
不言オリジナル
2018-06-19 16:38:181684ブラウズ

この記事では主に PHP の var_export、print_r、var_dump のデバッグの違いを紹介します。これは非常に優れており、必要な方は参考にしてください。

1タイプ

コード

$n = "test";
var_export($n);
print_r($n);
var_dump($n);
echo &#39;-----------------&#39; . &#39;<br/><br/>&#39;;
file_put_contents("index.log", var_export($n, true) . PHP_EOL, FILE_APPEND);
file_put_contents("index.log", print_r($n, true) . PHP_EOL, FILE_APPEND);
file_put_contents("index.log", var_dump($n) . PHP_EOL, FILE_APPEND);

結果

(1) フロントエンド:

'test' テスト /Users/xjnotxj/Program/PhpstormProject/colin/index.php:9:string 'test' (length=4) ----------------- /ユーザー /xjnotxj/Program/PhpstormProject/colin/index.php:15:string 'test' (length=4)

(2)index.log:

'test'テスト

2、出力配列

コード

$arr = array(
  "a" => 1,
  "b" => "222",
  "c" => 3,
);
var_export($arr);
print_r($arr);
var_dump($arr);
echo &#39;-----------------&#39; . &#39;<br/><br/>&#39;;
file_put_contents("index.log", var_export($arr, true) . PHP_EOL, FILE_APPEND);
file_put_contents("index.log", print_r($arr, true) . PHP_EOL, FILE_APPEND);
file_put_contents("index.log", var_dump($arr) . PHP_EOL, FILE_APPEND);

結果

( 1) フロントエンド:

array ( 'a' => 1, 'b' => '222', 'c' => 3, ) Array ( [a] = > 1 [b] => 222 [c] => 3 ) /Users/xjnotxj/Program/PhpstormProject/colin/index.php:13: 'a' => int; b' => 文字列 '222' (長さ=3) 'c' => int 3 ----------------- /Users/xjnotxj/Program/PhpstormProject/colin/インデックス。php:19: 配列 (サイズ=3) 'a' => int 1 'b' => 文字列 '222' (長さ=3) 'c' => int; ## (2)index.log:

array ( &#39;a&#39; => 1, &#39;b&#39; => &#39;222&#39;, &#39;c&#39; => 3, ) Array ( [a] => 1 [b] => 222 [c] => 3 )

3、出力オブジェクト

コード

class foo
{
  public $n;
  public function do_foo()
  {
    echo "Doing foo." . $this->n;
  }
}
$object = new foo;
var_export($object);
print_r($object);
var_dump($object);
echo &#39;-----------------&#39; . &#39;<br/><br/>&#39;;
file_put_contents("index.log", var_export($object, true) . PHP_EOL, FILE_APPEND);
file_put_contents("index.log", print_r($object, true) . PHP_EOL, FILE_APPEND);
file_put_contents("index.log", var_dump($object) . PHP_EOL, FILE_APPEND);

Result

(1) フロントエンド:

foo::__set_state(array( 'n' => NULL) , ))

foo Object ([n] => )
/Users/xjnotxj/Program/PhpstormProject/colin/index.php:19: object(foo)[1] public 'n' => null -- --------------- /Users/xjnotxj/Program/PhpstormProject/colin/index.php:25: object(foo)[1] public 'n' =>



(2)index.log:

foo::__set_state(array( &#39;n&#39; => NULL, )) foo Object ( [n] => )

##概要:

#1. 詳細な出力結果: var_export ≈ print_r < var_dump2. デバッグ時に var_export、print_r、var_dump を呼び出すときに、前に echo を追加する必要はありません。

3. var_export と print_r の 2 番目のパラメータが true の場合、値が返されます。 var_dump は をサポートしていないため、file_put_contents を使用してデバッグを出力する場合は var_dump を使用しないでください。

4. 開発環境でのデバッグには var_dump を直接使用して、詳細なデバッグ情報とコード行の位置を取得することをお勧めします。実稼働環境でのデバッグには var_export または print_r を使用することを忘れないでください。フロントエンド インフルエンス ラインに直接出力するのではなく、値を返す場合は true。

上記がこの記事の全内容です。その他の関連コンテンツについては、PHP 中国語 Web サイトをご覧ください。

関連する推奨事項:

PHP を使用して中国語のピンイン変換とグレゴリオ暦と旧暦の変換を実装する

PHP の move_uploaded_file( ) 関数分析


以上がPHPのデバッグにおけるvar_export、print_r、var_dumpの違いについての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。