• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

PHP中var_export、print_r、var_dump调试中的区别

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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 转为返回输出值,而不是直接输出到前端影响线上。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
php序列化与反序列化发布时间:2022-07-10
下一篇:
php获取当前是星期几发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap