PHP unset全局变量在实际使用中只能销毁局部变量,并不能实现全局变量的目的。下面我们就来具体解决这一问题。希望对大家有所帮助。
PHP中语言中有些函数对于初学者来说在字面上是很难理解的,需要在实际编码中总结经验,来掌握这些知识。我们今天要为大家介绍的是PHP unset全局变量在使用中遇到的一些问题。
PHP 中有个释放变量的语句叫做unset(从PHP4开始unset已经不再是一个函数了,而是一个语句),前几天用unset的时候出了点问题,于是把 unset问题总结如下。如果您仔细阅读过PHP的手册,那么就没必要再看这篇文章了,这篇文章是写给看手册不用心的同学的。
首先要强调的一点是PHP unset全局变量在PHP中已经不再是一个函数了,既然不是函数,那么就没有了返回值,所以用的时候不能够用unset的返回值来做判断。
其次,在函数中,PHP unset全局变量只能销毁局部变量,并不能销毁全局变量,来看下手册的一个例子
复制代码 代码如下:
function destroy_foo() {
global $foo;
unset($foo);
}
$foo = ‘bar';
destroy_foo();
echo $foo;
?>
复制代码 代码如下:
function foo() {
unset($GLOBALS['bar']);
}
$bar = “something”;
foo();
var_dump($bar);
?>
复制代码 代码如下:
$test=str_repeat("1",256); //重复一个字符串,返回值为重复后组成的字符串
$s = memory_get_usage();
//该函数用来查看当前所用内存
unset($test);
$e = memory_get_usage();
echo ' 释放内存: '.($s-$e);
//输出为272,但如果上面test变量改为$test=str_repeat("1",255),输出则为0 ,变量值不足256不会释放内存的
?>
复制代码 代码如下:
$test = str_repeat("1",256);
$p = &$test;
unset($test);
echo $p;
//输出为256个1。如果上面改为unset($p),更不行了,echo $test 直接显示为256个1
?>
复制代码 代码如下:
$test = str_repeat("1",256);
$p = &$test;
$s = memory_get_usage();
$test = null;
unset($test); //试一下将该句与$test=null 调换先后顺序,则结果将不相同
$e = memory_get_usage();
echo ' 释放内存: '.($s-$e);
//输出为272
var_dump($p); //输出为NULL
?>
复制代码 代码如下:
$test = str_repeat("1",256);
$p = &$test;
$s = memory_get_usage();
//注意,以下2个unset()顺序对调没有关系,不影响结果
unset($p);
unset($test);
$e = memory_get_usage();
echo ' 释放内存: '.($s-$e); //输出为272
?>