首頁  >  文章  >  後端開發  >  關於PHP中var_export和print_r以及var_dump在調試中的區別

關於PHP中var_export和print_r以及var_dump在調試中的區別

不言
不言原創
2018-06-19 16:38:181575瀏覽

這篇文章主要介紹了PHP 中var_export、print_r、var_dump 調試中的區別,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

#1、output basic type

程式碼

$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'  test  /Users/xjnotxj/Program/PhpstormProject/colin/index.php:9:string 'test' (length=4)  -----------------  /Users /xjnotxj/Program/PhpstormProject/colin/index.php:15:string 'test' (length=4)

(2)index.log:

'test'  test

2、output array

程式碼

#
$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:  array (size=3)  'a' => int 1  'b' => string '222' (length=3)  'c' => int 3  -----------------  /Users/xjnotxj/Program/PhpstormProject/colin/index. php:19:  array (size=3)  'a' => int 1  'b' => string '222' (length=3)  'c' => int 3

# (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、output object

程式碼

#
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);

結果


(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' => null

(2)index.log:

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

#總結:

1、輸出結果的詳細性: var_export ≈ print_r < var_dump

2、調試的時候,呼叫var_export、print_r、var_dump 的時候, 不用在前加echo 。

3、var_export,print_r 的 第二個參數為true則回傳值。 var_dump 不支援 ,所以用 file_put_contents 輸出調試的時候不要用 var_dump。

4、推薦開發環境的調試直接使用var_dump,可以獲得詳細的調試資訊和程式碼行數定位;生產環境的調試使用var_export 或print_r,第二個參數記得設定為true 轉為回傳輸出值,而不是直接輸出到前端影響線上。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網! 相關推薦:

使用PHP實作漢字拼音轉換和公曆農曆轉換

關於PHP的move_uploaded_file() 函數的解析

############

以上是關於PHP中var_export和print_r以及var_dump在調試中的區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn