一帖搞懂PHP销毁(unset,null,php自释放,析构函数)

原创 2017-01-04 10:28:34 547
摘要:PHP的变量或对象的销毁如果说一定要分类,那么可以分成两种那就是显式销毁和隐式销毁      1、显式销毁,当对象没有被引用时就会被销毁,所以我们可以unset或为其赋值NULL;      2、隐式销毁,PHP是脚本语言,在代码执行完最后一行时,所有申请的内存都要释放掉.   

PHP的变量或对象的销毁如果说一定要分类,那么可以分成两种那就是显式销毁和隐式销毁 
     1、显式销毁,当对象没有被引用时就会被销毁,所以我们可以unset或为其赋值NULL; 
     2、隐式销毁,PHP是脚本语言,在代码执行完最后一行时,所有申请的内存都要释放掉.
     从上面两种销毁方式中,我们可以总结出销毁的三种方法:那就是1、unset(),2、$varname=null,3、PHP自销毁,我们还要加上一个,那就是4、析构函数__destruct()。
     作为小白的我们能搞明白上面四种变量或对象的销毁吗?如果不能搞明白,我们就举出一个例子给大家,方便大家理解。

<?php 
class Human { 
  public $name = '张三'; 
  public $gender = null; 
  public function __destruct() { 
      echo '死了!<br />'; 
  } 
} 
$a = new Human(); 
$b = $c = $d = $a;
unset($a);
$d=null;
echo '<hr />';
var_dump($a);
echo '<hr />';
var_dump($b);
echo '<hr />';
var_dump($c);
echo '<hr />';
var_dump($d);


    那以上变量打印出的结果是什么呢?就是下面这部分:


Notice: Undefined variable: a in E:\amp\apache\htdocs\index.php on line 14
NULL

object(Human)#1 (2) { ["name"]=> string(4) "张三" ["gender"]=> NULL }

object(Human)#1 (2) { ["name"]=> string(4) "张三" ["gender"]=> NULL }

NULL 死了!

     首先我们要知道,在PHP中,变量名是存储在内存栈中,它是指向堆中具体内存的地址,通过变量名查找堆中的内存; 因此我们可以得出结论:

      1、unset()不仅将变量内存释放了,而且变量名也变为没有定义,可见将变量都彻底删除掉了。但如果unset()是在引用传值那就又要注意了,举例:

<?php
        $a = 1;
        $b = &$a;
        unset($a);
        var_dump($a);
        var_dump($b);

本帖隐藏的内容

输出结果是:
Notice: Undefined variable: a in E:\amp\apache\htdocs\index.php on line 5
NULL int(1) 


所以unset()并没有真正销毁变量中内存值,仅仅是切断了变量与内存之间的关系,并将变量名也给干掉了,但内存只要还被引用着就不会被释放; 而在PHP中对象的传值默认是引用传值,这也解释了Human类中,$a被unset()了,但是$b = $c = $d 一样有值。

      2、$varname=null,变量名依然存在,但是内存值却被干掉了。那么在引用传值的情况下又是如何呢?举例:

<?php
        $a = 1;
        $b = &$a;
        $a=null;
        var_dump($a);
        var_dump($b);

    输出的结果是:
    NULL NULL
     所以,$varname=null,虽然变量名和内存指向都还存在,但是内存中的值却是完全删除掉了。

     3、从上例子可以看出,析构函数__destruct()是在PHP执行完最后一段代码的时候,才启动,但是这样理解并不够精准,
举例

<?php 
class Human{       
     public  $name = '开始';        
     public function __destruct(){                
     echo '结束';        
     }}
     $a = new Human;
     echo $a->name;
     unset($a);   //销毁函数 
     $a = new Human; 
     echo '<hr>';

输出的结果是:

开始结束


以上结果说明代码并没有执行完最后一行的时候启动,而是当对象销毁的时候.自动执行。之所以在human()函数也有unset()的情况下,析构函数__destruct()还是在最后执行,那是因为引用传值,对象的内存并没有取消,对象并没有完全销毁导致。所以结论是:如果没有人为销毁的话.则在代码执行结束之后,系统自动释放内存时执行析构函数__destruct(),如果对象有销毁的时候.则自动执行析构函数。


4、PHP自销毁
     如果我们搞明白了前面三种销毁,那么最后一种就很好理解了。除了上面三种特里以外,那就是PHP的自销毁了。代码运行在最后一行的时候,所有变量的内存都要销毁掉。这是PHP的特性!


发布手记

热门词条