Możesz to sprawdzić var_export
- chociaż nie zapewnia tego samego wyniku, ponieważ var_dump
zapewnia drugi $return
parametr, który spowoduje, że zwróci on wynik, zamiast go wydrukować:
$debug = var_export($my_var, true);
Dlaczego?
Wolę ten jednowarstwowy od używania ob_start
i ob_get_clean()
. Uważam również, że wynik jest nieco łatwiejszy do odczytania, ponieważ jest to po prostu kod PHP.
Różnica między var_dump
i var_export
polega na tym, że var_export
zwraca „reprezentatywny ciąg znaków zmiennej”, a var_dump
po prostu zrzuca informacje o zmiennej. W praktyce oznacza to, że var_export
daje ci prawidłowy kod PHP (ale może nie dawać ci tyle informacji o zmiennej, szczególnie jeśli pracujesz z zasobami ).
Próbny:
$demo = array(
"bool" => false,
"int" => 1,
"float" => 3.14,
"string" => "hello world",
"array" => array(),
"object" => new stdClass(),
"resource" => tmpfile(),
"null" => null,
);
// var_export -- nice, one-liner
$debug_export = var_export($demo, true);
// var_dump
ob_start();
var_dump($demo);
$debug_dump = ob_get_clean();
// print_r -- included for completeness, though not recommended
$debug_printr = print_r($demo, true);
Różnica w wydajności:
var_export ( $debug_export
w powyższym przykładzie):
array (
'bool' => false,
'int' => 1,
'float' => 3.1400000000000001,
'string' => 'hello world',
'array' =>
array (
),
'object' =>
stdClass::__set_state(array(
)),
'resource' => NULL, // Note that this resource pointer is now NULL
'null' => NULL,
)
var_dump ( $debug_dump
w powyższym przykładzie):
array(8) {
["bool"]=>
bool(false)
["int"]=>
int(1)
["float"]=>
float(3.14)
["string"]=>
string(11) "hello world"
["array"]=>
array(0) {
}
["object"]=>
object(stdClass)#1 (0) {
}
["resource"]=>
resource(4) of type (stream)
["null"]=>
NULL
}
print_r ( $debug_printr
w powyższym przykładzie):
Array
(
[bool] =>
[int] => 1
[float] => 3.14
[string] => hello world
[array] => Array
(
)
[object] => stdClass Object
(
)
[resource] => Resource id #4
[null] =>
)
Zastrzeżenie: var_export
nie obsługuje referencji okrągłych
Jeśli próbujesz zrzucić zmienną z referencjami cyklicznymi, wywołanie var_export
spowoduje ostrzeżenie PHP:
$circular = array();
$circular['self'] =& $circular;
var_export($circular);
Prowadzi do:
Warning: var_export does not handle circular references in example.php on line 3
array (
'self' =>
array (
'self' => NULL,
),
)
Zarówno , jak var_dump
i print_r
, z drugiej strony, wyprowadzi ciąg, *RECURSION*
gdy napotka okrągłe odwołania.