PHP 8.3.27 Released!

gc_status

(PHP 7 >= 7.3.0, PHP 8)

gc_statusGets information about the garbage collector

Description

gc_status(): array

Gets information about the current state of the garbage collector.

Parameters

This function has no parameters.

Return Values

Returns an associative array with the following elements:

  • "runs"
  • "collected"
  • "threshold"
  • "roots"
  • "running"
  • "protected"
  • "full"
  • "buffer_size"
  • "application_time"
  • "collector_time"
  • "destructor_time"
  • "free_time"

Changelog

Version Description
8.3.0 gc_status() now returns the following additional fields: "running", "protected", "full", "buffer_size", "application_time", "collector_time", "destructor_time", and "free_time".

Examples

Example #1 gc_status() Usage

<?php

// create object tree that needs gc collection
$a = new stdClass();
$a->b = [];
for (
$i = 0; $i < 100000; $i++) {
$b = new stdClass();
$b->a = $a;
$a->b[] = $b;
}
unset(
$a);
unset(
$b);
gc_collect_cycles();

var_dump(gc_status());

The above example will output something similar to:

array(4) {
 ["runs"]=>
 int(5)
 ["collected"]=>
 int(100002)
 ["threshold"]=>
 int(50001)
 ["roots"]=>
 int(0)
}

Output of the above example in PHP 8.3 is similar to:

array(12) {
 ["running"]=>
 bool(false)
 ["protected"]=>
 bool(false)
 ["full"]=>
 bool(false)
 ["runs"]=>
 int(5)
 ["collected"]=>
 int(100002)
 ["threshold"]=>
 int(50001)
 ["buffer_size"]=>
 int(131072)
 ["roots"]=>
 int(0)
 ["application_time"]=>
 float(0.031182458)
 ["collector_time"]=>
 float(0.020106291)
 ["destructor_time"]=>
 float(0)
 ["free_time"]=>
 float(0.003707167)
}

Found A Problem?

Learn How To Improve This PageSubmit a Pull RequestReport a Bug
+add a note

User Contributed Notes

There are no user contributed notes for this page.

AltStyle によって変換されたページ (->オリジナル) /