时间:2021-05-26
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
代码
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 '-----------------' . '<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 中 var_export、print_r、var_dump 调试中的区别,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言说到PHP代码调试,对于有经验的PHPer,通过echo、print_r、var_dump函数,或PHP开发工具zendstudio、editplus可解决
本文较为详细的分析了PHP中echo,print_r与var_dump区别。分享给大家供大家参考。具体分析如下:三者都是具有输出功能的php语句,但print_
php中有几种输出形式在php中有5种输出形式,分别是echo、print_r、print、var_dump和die。echo只能输出字符串等单一数据不能输出数
下面的示例看看这三个函数的具体的区别,其中var_dump和var_export比较少用,但他们两者又很相似。所以可以看看:复制代码代码如下:
AndroidSQLite数据库前言以前写PHP的时候,内置了print_r()和var_dump()两个函数用于打印输出任意类型的数据内部结构,现在做Andr