parse->start(); $vcard = $splitter->getNext(); $bench->parse->pause(); if (!$vcard) { break; } $bench->manipulate->start(); $vcard->{'X-FOO'} = 'Random new value!'; $emails = []; if (isset($vcard->EMAIL)) { foreach ($vcard->EMAIL as $email) { $emails[] = (string) $email; } } $bench->manipulate->pause(); $bench->serialize->start(); $vcard2 = $vcard->serialize(); $bench->serialize->pause(); $vcard->destroy(); } echo $bench,"\n"; function formatMemory($input) { if (strlen($input) > 6) { return round($input / (1024 * 1024)).'M'; } elseif (strlen($input) > 3) { return round($input / 1024).'K'; } } unset($input, $splitter); echo 'peak memory usage: '.formatMemory(memory_get_peak_usage()), "\n"; echo 'current memory usage: '.formatMemory(memory_get_usage()), "\n";