代码更好地说明了我的要求:
function foo(){
$var = get_huge_amount_of_data();
return $var[0];
}
$s = foo();
// is memory freed here for the $var variable created above?
do_other_stuff(); // need memory here lol
所以我知道$ var在某些时候会被释放,但PHP是否有效地做到了?或者我手动需要取消设置昂贵的变量吗?
答案 0 :(得分:7)
是的,它确实被释放了。
您可以使用以下方式检查:
function a() {
$var = "Hello World";
$content = "";
for ($i = 0; $i < 10000; $i++) {
$content .= $var;
}
print '<br>$content size:'.strlen($content);
print '<br>memory in function:'.memory_get_usage();
return null;
}
print '<br>memory before function:'.memory_get_usage();
a();
print '<br>memory after function:'.memory_get_usage();
输出:
memory before function:273312
$content size:110000
memory in function:383520
memory after function:273352
在函数PHP之前使用了273312个字节
在功能完成之前,我们再次检查了内存使用情况并使用了383520
我们检查了$ content的大小,即110000字节
273312 + 110000 = 383312
剩余的208个字节来自其他变量(我们只计算$ content)。在函数完成后,我们再次检查了内存使用情况,它回到了(几乎(40个字节的差异)),与之前相同。
40个字节的差异很可能是函数声明和for循环声明。
答案 1 :(得分:3)
你可以在类上看到这个例子,因为你可以“捕获”释放类'析构函数中的变量:
class a {
function __destruct(){
echo "destructor<br>";
}
}
function b(){ // test function
$c=new a();
echo 'exit from function b()<br>';
}
echo "before b()<br>";
b();
echo "after b()<br>";
die();
此脚本输出:
before b()
exit from function b()
destructor
after b()
现在很清楚,变量在函数退出时被销毁了。
答案 2 :(得分:2)
是的,因为$var
在堆栈上声明并且一旦超出范围就会变得清晰
答案 3 :(得分:2)
所以我知道$ var在某些时候会被释放,但PHP是否有效地做到了?或者我手动需要取消设置昂贵的变量吗?
是的,PHP做得很好。这是一个你永远不需要考虑的问题。在你的情况下,我宁愿考虑$var = ..
和return ..
之间的时刻,因为那是你无法避免记忆消耗的那一刻。你应该尝试找到一个解决方案,你不需要通过get_huge_amount_of_data()
获取整个数据集然后选择一个项目,而只选择你需要的数据。