有人可以解释什么情况下 gc_collect_cycles功能可以用吗?应该在大量的内存利用率即将发生之前被调用?
 
默认情况下,PHP已启用“垃圾收集器”.它用于释放“垃圾”使用的内存. 
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()删除).