gc_collect_cycles()强制收集任何现有的垃圾循环.它返回收集(释放)循环的数量(对象,变量值…).启用垃圾收集器不时调用此函数来释放资源.在大多数情况下,PHP脚本生活的时间很短.在这种情况下,所有垃圾将在工作结束时被破坏,而不会收集任何垃圾.
有时需要手动管理GC:
> gc_disable()可以加快一些长时间的操作,但也会导致一些内存开销.
> gc_collect_cycles()可用于指定GC的正确时刻.
另一个使用gc_collect_cycles()的原因 – 调试.假设你想知道memory_get_usage()的一些代码块的内存消耗是多少.您需要首先禁用GC,否则您会得到错误的结果.之后,您需要分离GC和应用程序所消耗的时间.所以调用gc_collect_cycles()并测量前后的时间/内存.
小例子
class A { public $ref; public $name; public function __construct($name) { $this->name = $name; echo($this->name.'->__construct();'.PHP_EOL); } public function __destruct() { echo($this->name.'->__destruct();'.PHP_EOL); } } gc_disable(); $a1 = new A('$a1'); $a2 = new A('$a2'); $a1->ref = $a2; $a2->ref = $a1; $b = new A('$b'); $b->ref = $a1; echo('$a1 = $a2 = $b = NULL;'.PHP_EOL); $a1 = $a2 = $b = NULL; echo('gc_collect_cycles();'.PHP_EOL); echo('// removed cycles: '.gc_collect_cycles().PHP_EOL); echo('exit();'.PHP_EOL);
会输出:
$a1->__construct(); $a2->__construct(); $b->__construct(); $a1 = $a2 => $b = NULL; $b->__destruct(); gc_collect_cycles(); $a2->__destruct(); $a1->__destruct(); // removed cycles: 4
这意味着当被问及时,只有b $b被销毁.其他$a1和$a2具有循环引用,它的名称属性也消耗内存.两个对象两个字符串= 4(由gc_collect_cycles()删除).