• PHP中变量的销毁


    PHP的变量或对象的销毁可以分成显式销毁和隐式销毁:

     1、显式销毁,当对象没有被引用时就会被销毁,所以我们可以unset或为其赋值NULL; 
     2、隐式销毁,PHP是脚本语言,在代码执行完最后一行时,所有申请的内存都要释放掉.
    

    从上面两种销毁方式中,我们可以总结出销毁的三种方法:那就是

    1、unset(),2、$varname=null,3、析构函数__destruct()。

    举例来说:

    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 /Library/WebServer/Documents/test.php on line 42
    NULL
    object(Human)#1 (2) { ["name"]=> string(6) "张三" ["gender"]=> NULL }
    object(Human)#1 (2) { ["name"]=> string(6) "张三" ["gender"]=> NULL }
    NULL 死了!

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

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

    结果是:
    Notice: Undefined variable: a in E:ampapachehtdocsindex.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 '***********************';
    
    输出的结果是:
    
    开始结束***************************结束
    class Human{       
         public  $name = '开始';        
         public function __destruct(){                
            echo '结束';        
         }}
         $a = new Human;
         $b = $a;
         echo $a->name;
         unset($a);   //销毁函数 
         $a = new Human; 
         echo '***************************';
    
    结果是:
    
    开始***************************结束结束

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

  • 相关阅读:
    设计模式 之 单例模式
    leetcode 69 x 的平方根 牛顿迭代法
    leetcode 98 验证二叉搜索树
    leetcode 54 螺旋数组
    第一篇-python入门
    python-入门
    python
    线性判别分析LDA总结
    LDA
    线性判别分析(LDA)原理
  • 原文地址:https://www.cnblogs.com/yolo-bean/p/7739604.html
Copyright © 2020-2023  润新知