1、output basic type
代码
$n = test var_export($n);print_r($n);var_dump($n);echo ----------------- . br/ br/ 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 ----------------- . br/ br/ 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 ( a = 1, b = 222 , c = 3, ) Array ( [a] = 1 [b] = 222 [c] = 3 )
3、output object
代码
html' target='_blank'>class foo public $n; public function do_foo() echo Doing foo. . $this- $object = new foo;var_export($object);print_r($object);var_dump($object);echo ----------------- . br/ br/ 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( n = 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教程
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答