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:\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 '***********************'; 输出的效果是: 最先完毕***************************完毕
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(),假如对象有烧毁的时刻,则自动实行析构函数。
引荐教程:PHP视频教程
以上就是php怎样删除变量的细致内容,更多请关注ki4网别的相干文章!