掌握PHP垃圾回收机制详解
php的垃圾回收机制可以简单总结为引用计数写时复制COW机制,
本文主要和大家分享掌握php垃圾回收机制的知识,希望能帮助到大家。
引用计数基本知识
官网的解答如下每个php变量存在一个叫”zval”的变量容器中一个zval变量容器,除了包含变量的类型和值,还包括两个字节的额外信息is_ref和refcountis_ref是个bool值,用来标识这个变量是否是属于引用集合(referenceset)。通过这个字节,php引擎才能把普通变量和引用变量区分开来refcount用以表示指向这个zval变量容器的变量个数PHP5中的引用计数在PHP5中,zval的内存是单独从堆(heap)中分配的(有少数例外情况),PHP需要知道哪些zval是正在使用的,哪些是需要释放的。所以这就需要用到引用计数:zval中refcount__gc的值用于保存zval本身被引用的次数,比如b=12语句中,12被两个变量引用,所以它的引用计数就是2。如果引用计数变成0,就意味着这个变量已经没有用了,内存也就可以释放了。
如下:
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 结果如下 a:(refcount=2,is_ref=1),int1b:(refcount=2,is_ref=0),int1c:(refcount=2,is_ref=1),int1d:(refcount=2,is_ref=0),int1e:(refcount=1,is_ref=0),array(size=4)0=>(refcount=1,is_ref=0),int01=>(refcount=1,is_ref=0),int12=>(refcount=1,is_ref=0),int23=>(refcount=1,is_ref=0),int3
每一个变量都记了自己的数PHP7中的zval在PHP7中zval有了新的实现方式。最基础的变化就是zval需要的内存不再是单独从堆上分配,不再自己存储引用计数。复杂数据类型(比如字符串、数组和对象)的引用计数由其自身来存储。这种实现方式有以下好处:简单数据类型不需要单独分配内存,也不需要计数不会再有两次计数的情况,在对象中,只有对象自身存储的计数是有效的由于现在计数由数值自身存储,所以也就可以和非zval结构的数据共享,比如zval和hashtablekey之间间接访问需要的指针数减少了
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>结果如下a:(refcount=2,is_ref=1)int1b:(refcount=0,is_ref=0)int1c:(refcount=2,is_ref=1)int1d:(refcount=0,is_ref=0)int1e:(refcount=1,is_ref=0)array(size=4)0=>(refcount=0,is_ref=0)int01=>(refcount=0,is_ref=0)int12=>(refcount=0,is_ref=0)int23=>(refcount=0,is_ref=0)int3
普通变量不再记自己的数,数组这样的复杂类型记自己的数什么是垃圾只有在准则3下,GC才会把zval收集起来,然后通过新的算法来判断此zval是否为垃圾。那么如何判断这么一个变量是否为真正的垃圾呢?简单的说,就是对此zval中的每个元素进行一次refcount减1操作,操作完成之后,如果zval的refcount=0,那么这个zval就是一个垃圾如果一个zval的refcount增加,那么此zval还在使用,不属于垃圾如果一个zval的refcount减少到0,那么zval可以被释放掉,不属于垃圾如果一个zval的refcount减少之后大于0,那么此zval还不能被释放,此zval可能成为一个垃圾
以上所述是小编给大家介绍的PHP垃圾回收机制详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!