3v4l.org

run code in 300+ PHP versions simultaneously
<?php $input = [ 'a', ['b', 'c'], 'd', ['e'], ['f', 'g'], ['h', 'i', ['j', ['k'], ['l', 'm', ['n']]]], 'o', 'p', ['q', 'r'], ['s', ['t', ['u', ['v']]]], 'w', 'x', 'y', 'z']; class TraversableInput implements \IteratorAggregate { public $input = [ 'a', ['b', 'c'], 'd', ['e'], ['f', 'g'], ['h', 'i', ['j', ['k'], ['l', 'm', ['n']]]], 'o', 'p', ['q', 'r'], ['s', ['t', ['u', ['v']]]], 'w', 'x', 'y', 'z']; function getIterator() { return new ArrayIterator($this->input); } } $input = new TraversableInput(); function flatten1($input) { return \array_reduce( $input, function ($carry, $item) { return \is_array($item) ? \array_merge($carry, flatten1($item)) : \array_merge($carry, [$item]); }, [] ); } function flatten2($input) { $stack = [$input]; $result = []; while (!empty($stack)) { $item = array_shift($stack); if (is_array($item) || $item instanceof Traversable) { foreach ($item as $element) { array_unshift($stack, $element); } } else { array_unshift($result, $item); } } return $result; } $start = microtime(TRUE); for($x=0;$x<10000;$x++){ flatten1($input); }; $end = microtime(TRUE); $diff = $end-$start; $sec = intval($diff); $micro = $diff - $sec; $final = strftime('%T', mktime(0, 0, $sec)) . str_replace('0.', '.', sprintf('%.10f', $micro)); echo "Flatten1: " . $final . "\n"; $start = microtime(TRUE); for($x=0;$x<10000;$x++){ flatten2($input); }; $end = microtime(TRUE); $diff = $end-$start; $sec = intval($diff); $micro = $diff - $sec; $final = strftime('%T', mktime(0, 0, $sec)) . str_replace('0.', '.', sprintf('%.10f', $micro)); echo "Flatten2: " . $final . "\n";

Here you find the average performance (time & memory) of each version. A grayed out version indicates it didn't complete successfully (based on exit-code).

VersionSystem time (s)User time (s)Memory (MiB)
7.2.100.1080.00714.38
7.2.90.0930.00914.76
7.2.80.1060.01014.53
7.2.70.1200.01314.89
7.2.60.1020.01314.95
7.2.50.0790.00914.73
7.2.40.0900.01314.95
7.2.30.1180.00314.95
7.2.20.0810.01414.89
7.2.10.1400.00914.93
7.2.00.0790.00015.13
7.1.220.0880.01513.75
7.1.210.0840.00313.83
7.1.200.0640.01613.75
7.1.190.0780.00713.67
7.1.180.1310.01013.84
7.1.170.1210.00313.73
7.1.160.1030.00714.02
7.1.150.1110.00713.73
7.1.140.0710.00913.61
7.1.130.2150.00313.86
7.1.120.0960.00913.93
7.1.110.0660.00713.83
7.1.100.0770.01013.89
7.1.90.1020.00713.70
7.1.80.1100.01213.76
7.1.70.0770.00013.84
7.1.60.1160.00731.85
7.1.50.1110.01631.83
7.1.40.0840.01331.98
7.1.30.1390.01931.73
7.1.20.1580.00331.79
7.1.10.1210.00313.66
7.1.00.1140.01313.87

preferences:
30.85 ms | 400 KiB | 5 Q