php 调试工具及学习PHP垃圾回收机制了解引用计数器的概念

php代码工具:Xdebug  与分析工具 WinCacheGrind

Xdebug之函数大全:

string xdebug_call_class()返回当前被调用的函数或方法所属的类的类名


string xdebug_call_file()返回调用当前函数的文件名


string xdebug_call_function()返回调用当前正在执行的函数的函数名


int xdebug_call_line()返回该函数是在哪一行被调用的。


void xdebug_disable()/xdebug_enable()禁止/激活显示错误的跟踪栈信息


xdebug_start_error_collection()xdebug_stop_error_collection()xdebug_get_collected_errors()
错误收集开始函数,当此函数被执行的时候,xdebug将不在页面上显示错误信息,而是将错误信息以xdebug
自己的规则记录在缓冲区。直到遇到xdebug_stop_error_collection()函数。缓冲区的内容将由xdebug_get_collected_errors()
函数的调用而显示。此功能可以让你的页面不被xdebug的错误显示破坏。


array xdebug_get_headers()返回所有由php设置的头信息。比如由header(),setcookie函数设置的头信息.


xdebug_is_enabled()返回xdebug的跟踪状态是否被激活 xdebug.default_enable的值


int xdebug_memory_usage()返回脚本当前的内存使用数


int xdebug_peak_memory_usage()返回脚本直达目前为止这段过程中的使用内存的最高值


float xdebug_time_index()返回脚本开始到现在所使用的秒数


变量显示功能

var_dump( [mixed var [, ...]])
void xdebug_debug_zval( [stringvarname [, ...]] )
void xdebug_debug_zval_stdout([string varname [, ...]] )
返回一个变量的标准输出信息,包括类型,值,引用次数等。。


void xdebug_dump_superglobals()返回全局变量的信息


void xdebug_var_dump( [mixed var [,...]] ) 显示变量的详细信息

堆栈跟踪

array xdebug_get_declared_vars()返回申明的变量集合

array xdebug_get_function_stack()返回跟踪栈的详细信息(跟踪函数执行步骤)

函数跟踪
xdebug_start_code_coverage()
开始跟踪

arrayxdebug_get_code_coverage()
返回代码执行去向

 

 

php变量存在一个叫"zval"的变量容器中,"zval"变量容器包括含变量的类型和值,还包括额外的两个字节信息,分别是“is_ref”表示变量是否属于引用,“refcount”指向这个zval变量容器的变量个数。

如果你安装了xdebug,就可以用xdebug_debug_zval()显示“zval”的信息了。如下:

?
<?php
     $str = "phpddt.com" ;
     xdebug_debug_zval( 'str' );

  

结果:

str:

(refcount=1, is_ref=0),

string 'phpddt.com' (length=10)

只有当变量容器在”refcount“变成0时就被销毁.当你unset()一个变量时,想要的“zval”中refcount就会减1,再来说说前几天遇到的unset引用问题

?
<?php
     $a = "aaa" ;
     $b = & $a ;
     unset( $a );
     //echo $b; //这里依然会输出aaa,用xdebug_debug_zval打印你就知道为什么了
     xdebug_debug_zval( "b" );

  

结果:

b:

(refcount=1, is_ref=0),string 'aaa' (length=3)

继续说引用计数器问题,对于array和object符合类型情况又不一样了:

?
<?php
     /** by www.phpddt.com */
     $arr = array ( 'a' => 'aaa' , 'b' => "bbb" );
     xdebug_debug_zval( 'arr' );
     $arr [ 'aaa' ] = $arr [ 'a' ];
     xdebug_debug_zval( 'arr' );
?>

  

结果:

arr:

(refcount=1, is_ref=0),

array

  'a' => (refcount=1, is_ref=0),string 'aaa' (length=3)

  'b' => (refcount=1, is_ref=0),string 'bbb' (length=3)

arr:

(refcount=1, is_ref=0),

array

  'a' => (refcount=2, is_ref=0),string 'aaa' (length=3)

  'b' => (refcount=1, is_ref=0),string 'bbb' (length=3)

  'aaa' => (refcount=2, is_ref=0),string 'aaa' (length=3)

可以看到看到原有的数组元素和新添加的数组元素关联到同一个"refcount"2的zval变量容器.这里我也只是起到抛砖引玉的作用。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值