unset($_sub);//用完及时销毁
}
unset($farr);
这里,不难看出,一方面,我们要增加 PHP 可用内存大小,另一方面,只要我们想
办法对数组进行分批处理,分而治之,将用过的变量及时销毁(unset),一般是不会出现
溢出问题的。
另外,为了节省 PHP 程序内存损耗,我们应当尽可能减少静态变量的使用,在需要
数据重用时,可以考虑使用引用(&)。再一点就是:数据库操作完成后,要马上关闭连接;
一个对象使用完,要及时调用析构函数(__destruct())。
二.unset 销毁变量并释放内存问题
PHP 的 unset()函数用来清除、销毁变量,不用的变量,我们可以用 unset()将它销
毁。但是某些时候,用 unset()
却无法达到销毁变 量占用的内存!我们先看一个例子:
代码如下:
<?php
$s=str_repeat('1',255); //产生由 255 个 1 组成的字符串
$m=memory_get_usage(); //获取当前占用内存
unset($s);
$mm=memory_get_usage(); //unset()后再查看当前占用内存
echo $m-$mm;
?>
最后输出 unset()之前占用内存减去 unset()之后占用内存,如果是正数,那么说明
unset($s)已经将$s 从内存中销毁(或者说,unset()之后内存占用减少了),可是我在
PHP5 和 windows 平台下,得到的结果是:0。这是否可以说明,unset($s)
并没有起 到
销毁变量$s 所占用内存的作用呢?我们再作下面的例子:
代码如下:
<?php
$s=str_repeat('1',256); //产生由 256 个 1 组成的字符串
$m=memory_get_usage(); //获取当前占用内存
unset($s);
$mm=memory_get_usage(); //unset()后再查看当前占用内存
echo $m-$mm;
?>
这个例子,和上面的例子几乎相同,唯一的不同是,$s 由 256 个 1 组成,即比第一
个例子多了一个 1,得到结果是:272
。这是否可以说 明,unset($s)已经将$s 所占用的
内存销毁了?
通过上面两个例子,我们可以得出以下结论:
结论一、unset()函数只能在变量值占用内存空间超过 256 字节时才会释放内存空间。
那么是不是只要变量值超过 256,使用 unset 就可以释放内存空间呢?我们再通过
一个例子来测试一下:
代码如下:
<?php
$s=str_repeat('1',256); //这和第二个例子完全相同