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


Posted in PHP onJune 19, 2018

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 调试中的区别,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

PHP 相关文章推荐
php框架Phpbean说明
Jan 10 PHP
php中大括号作用介绍
Mar 22 PHP
PHP中的str_repeat函数在JavaScript中的实现
Sep 16 PHP
php比较两个绝对时间的大小
Jan 31 PHP
PHP生成压缩文件实例
Feb 07 PHP
php修改上传图片尺寸的方法
Apr 14 PHP
PHP生成唯一订单号的方法汇总
Apr 16 PHP
PHP中通过trigger_error触发PHP错误示例
Jun 23 PHP
Yii控制器中操作视图js的方法
Jul 04 PHP
windows环境下使用Composer安装ThinkPHP5
May 18 PHP
ThinkPHP5.0多个文件上传后找不到临时文件的修改方法
Jul 30 PHP
php正则表达式使用方法整理集合
Jan 31 PHP
总结PHP代码规范、流程规范、git规范
Jun 18 #PHP
针对thinkPHP5框架存储过程bug重写的存储过程扩展类完整实例
Jun 16 #PHP
PHP mongodb操作类定义与用法示例【适合mongodb2.x和mongodb3.x】
Jun 16 #PHP
PHP实现redis限制单ip、单用户的访问次数功能示例
Jun 16 #PHP
PHP基于rabbitmq操作类的生产者和消费者功能示例
Jun 16 #PHP
PHP7.1实现的AES与RSA加密操作示例
Jun 15 #PHP
PHP观察者模式示例【Laravel框架中有用到】
Jun 15 #PHP
You might like
浅析linux下apache服务器的配置和管理
2013/08/10 PHP
php生成EAN_13标准条形码实例
2013/11/13 PHP
PHP随手笔记整理之PHP脚本和JAVA连接mysql数据库
2015/11/25 PHP
PHP5.5基于mysqli连接MySQL数据库和读取数据操作实例详解
2019/02/16 PHP
php ajax confirm 删除实例详解
2019/03/06 PHP
基于jquery点击自以外任意处,关闭自身的代码
2012/02/10 Javascript
js定时调用方法成功后并停止调用示例
2014/04/08 Javascript
js判断登录与否并确定跳转页面的方法
2015/01/30 Javascript
Python脚本后台运行的几种方式
2015/03/09 Javascript
JS+CSS实现DIV层的展开、收缩效果
2016/01/28 Javascript
H5实现中奖记录逐行滚动切换效果
2017/03/13 Javascript
Vue中之nextTick函数源码分析详解
2017/10/17 Javascript
vue路由前进后退动画效果的实现代码
2018/12/10 Javascript
JavaScript实现汉字转换为拼音及缩写的方法示例
2019/03/28 Javascript
微信小程序自定义导航栏实例代码
2019/04/05 Javascript
js实现微信聊天效果
2020/08/09 Javascript
解决VUE项目使用Element-ui 下拉组件的验证失效问题
2020/11/07 Javascript
[06:21]完美世界亚洲区首席发行官竺琦TI3采访
2013/08/26 DOTA
[01:14]辉夜杯战队访谈宣传片—NEWBEE.Y
2015/12/26 DOTA
Python 编码Basic Auth使用方法简单实例
2017/05/25 Python
python爬虫实战之最简单的网页爬虫教程
2017/08/13 Python
python判断字符串是否是json格式方法分享
2017/11/07 Python
python 解压pkl文件的方法
2018/10/25 Python
pandas的相关系数与协方差实例
2019/12/27 Python
python 写函数在一定条件下需要调用自身时的写法说明
2020/06/01 Python
Python SMTP配置参数并发送邮件
2020/06/16 Python
路德维希•贝克(LUDWIG BECK)中文官网:德国大型美妆百货
2020/09/19 全球购物
北京某科技有限公司C# .net笔试题
2014/09/27 面试题
高二英语教学反思
2014/01/19 职场文书
贷款担保申请书
2014/05/20 职场文书
社区娱乐活动方案
2014/08/21 职场文书
业务员岗位职责
2015/02/03 职场文书
2015年保育员个人工作总结
2015/05/13 职场文书
导游词之南京莫愁湖公园
2019/11/13 职场文书
详解CSS玩转图片Base64编码
2021/05/25 HTML / CSS
python利用pandas分析学生期末成绩实例代码
2021/07/09 Python