3v4l.org

run code in 150+ php & hhvm versions
Bugs & Features
<?php namespace Hoa\Bench { class Mark { /** * Mark ID. * * @var \Hoa\Bench\Mark string */ protected $_id = null; /** * Start time. * * @var \Hoa\Bench\Mark float */ protected $start = 0.0; /** * Stop time. * * @var \Hoa\Bench\Mark float */ protected $stop = 0.0; /** * Addition of pause time. * * @var \Hoa\Bench\Mark float */ protected $pause = 0.0; /** * Whether the mark is running. * * @var \Hoa\Bench\Mark bool */ protected $_running = false; /** * Whether the mark is in pause. * * @var \Hoa\Bench\Mark bool */ protected $_pause = false; /** * Built a mark (and set the ID). * * @access public * @param string $id The mark ID. * @return void */ public function __construct ( $id ) { $this->setId($id); return; } /** * Set the mark ID. * * @access protected * @param string $id The mark ID. * @return string */ protected function setId ( $id ) { $old = $this->_id; $this->_id = $id; return $old; } /** * Get the mark ID. * * @access public * @return string */ public function getId ( ) { return $this->_id; } /** * Start the mark. * A mark can be started if it is in pause, stopped, or if it is the first start. * Else, an exception will be thrown. * * @access public * @return \Hoa\Bench\Mark * @throw \Hoa\Bench\Exception */ public function start ( ) { if(true === $this->isRunning()) if(false === $this->isPause()) throw new Exception( 'Cannot start the %s mark, because it is running.', 0, $this->getId()); if(true === $this->isPause()) $this->pause += microtime(true) - $this->stop; else { $this->reset(); $this->start = microtime(true); } $this->_running = true; $this->_pause = false; return $this; } /** * Stop the mark. * A mark can be stopped if it is in pause, or started. Else, an exception * will be thrown (or not, according to the $silent argument). * * @access public * @param bool $silent If set to true and if the mark is not running, * no exception will be thrown. * @return \Hoa\Bench\Mark * @throw \Hoa\Bench\Exception */ public function stop ( $silent = false ) { if(false === $this->isRunning()) if(false === $silent) throw new Exception( 'Cannot stop the %s mark, because it is not running.', 1, $this->getId()); else return $this; $this->stop = microtime(true); $this->_running = false; $this->_pause = false; return $this; } /** * Reset the mark. * * @access public * @return \Hoa\Bench\Mark */ public function reset ( ) { $this->start = 0.0. $this->stop = 0.0; $this->pause = 0.0; $this->_running = false; $this->_pause = false; return $this; } /** * Pause the mark. * A mark can be in pause if it is started. Else, an exception will be * thrown (or not, according to the $silent argument). * * @access public * @param bool $silent If set to true and the mark is not running, * no exception will be throw. Idem if the mark * is in pause. * @return \Hoa\Bench\Mark * @throw \Hoa\Bench\Exception */ public function pause ( $silent = false ) { if(false === $this->isRunning()) if(false === $silent) throw new Exception( 'Cannot stop the %s mark, because it is not running.', 2, $this->getId()); else return $this; if(true === $this->isPause()) if(false === $silent) throw new Exception( 'The %s mark is still in pause. Cannot pause it again.', 3, $this->getId()); else return $this; $this->stop = microtime(true); $this->_pause = true; return $this; } /** * Get the difference between $stop and $start. * If the mark is still running (it contains the pause case), the current * microtime will be used in stay of $stop. * * @access public * @return float */ public function diff ( ) { if(false === $this->isRunning() || true === $this->isPause()) return $this->stop - $this->start - $this->pause; return microtime(true) - $this->start - $this->pause; } /** * Compare to mark. * $a op $b : return -1 if $a < $b, 0 if $a == $b, and 1 if $a > $b. We * compare the difference between $start and $stop, i.e. we call the diff() * method. * * @access public * @param \Hoa\Bench\Mark $mark The mark to compare to. * @return int */ public function compareTo ( Mark $mark ) { $a = $this->diff(); $b = $mark->diff(); if($a < $b) return -1; elseif($a == $b) return 0; else return 1; } /** * Check if the mark is running. * * @access public * @return bool */ public function isRunning ( ) { return $this->_running; } /** * Check if the mark is in pause. * * @access public * @return bool */ public function isPause ( ) { return $this->_pause; } /** * Alias of the diff() method, but return a string, not a float. * * @access public * @return string */ public function __toString ( ) { return (string) $this->diff(); } } class Bench implements \Iterator, \Countable { /** * Statistic : get the result. * * @const int */ const STAT_RESULT = 0; /** * Statistic : get the pourcent. * * @const int */ const STAT_POURCENT = 1; /** * Collection of marks. * * @var \Hoa\Bench array */ protected static $_mark = array(); /** * Collection of filters. * * @var \Hoa\Bench array */ protected $_filters = array(); /** * Get a mark. * If the mark does not exist, it will be automatically create. * * @access public * @param string $id The mark ID. * @return \Hoa\Bench\Mark * @throw \Hoa\Bench\Exception */ public function __get ( $id ) { if(true === $this->markExists($id)) return self::$_mark[$id]; $mark = new Mark($id); self::$_mark[$id] = $mark; return $mark; } /** * Check if a mark exists. * Alias of the protected markExist method. * * @access public * @param string $id The mark ID. * @return bool */ public function __isset ( $id ) { return $this->markExists($id); } /** * Destroy a mark. * * @access public * @param string $id The mark ID. * @return void */ public function __unset ( $id ) { unset(self::$_mark[$id]); return; } /** * Destroy all mark. * * @access public * @return void */ public function unsetAll ( ) { self::$_mark = array(); return; } /** * Check if a mark already exists. * * @access protected * @param string $id The mark ID. * @return bool */ protected function markExists ( $id ) { return isset(self::$_mark[$id]); } /** * Get the current mark for the iterator. * * @access public * @return \Hoa\Bench\Mark */ public function current ( ) { return current(self::$_mark); } /** * Get the current mark ID for the iterator. * * @access public * @return string */ public function key ( ) { return key(self::$_mark); } /** * Advance the internal mark collection pointer, and return the current * mark. * * @access public * @return \Hoa\Bench\Mark */ public function next ( ) { return next(self::$_mark); } /** * Rewind the internal mark collection pointer, and return the first mark. * * @access public * @return \Hoa\Bench\Mark */ public function rewind ( ) { return reset(self::$_mark); } /** * Check if there is a current element after calls the rewind or the next * methods. * * @access public * @return bool */ public function valid ( ) { if(empty(self::$_mark)) return false; $key = key(self::$_mark); $return = (next(self::$_mark) ? true : false); prev(self::$_mark); if(false === $return) { end(self::$_mark); if($key === key(self::$_mark)) $return = true; } return $return; } /** * Add a filter. * Used in the self::getStatistic() method, no in iterator. * A filter is a callable that will receive 3 values about a mark: ID, time * result, and time pourcent. The callable must return a boolean. * * @access public * @param mixed $callable Callable. * @return void */ public function filter ( $callable ) { $this->_filters[] = xcallable($callable); return $this; } /** * Return all filters. * * @access public * @return array */ public function getFilters ( ) { return $this->_filters; } /** * Get statistic. * Return an associative array : id => sub-array. The sub-array contains the * result time in second (given by the constant self::STAT_RESULT), and the * result pourcent (given by the constant self::START_POURCENT). * * @access public * @param bool $considerFilters Whether we should consider filters or * not. * @return array */ public function getStatistic ( $considerFilters = true ) { if(empty(self::$_mark)) return array(); $max = $this->getLongest()->diff(); $out = array(); foreach($this as $id => $mark) { $result = $mark->diff(); $pourcent = ($result * 100) / $max; if(true === $considerFilters) foreach($this->getFilters() as $filter) if(true !== $filter($id, $result, $pourcent)) continue 2; $out[$id] = array( self::STAT_RESULT => $result, self::STAT_POURCENT => $pourcent ); } return $out; } /** * Get the maximum, i.e. the longest mark in time. * * @access public * @return \Hoa\Bench\Mark */ public function getLongest ( ) { $max = 0; $outMark = null; foreach($this as $id => $mark) if($mark->diff() > $max) { $outMark = $mark; $max = $mark->diff(); } return $outMark; } /** * Draw statistic in text mode. * * @access public * @param int $width The graphic width. * @return string * @throw \Hoa\Bench\Exception */ public function drawStatistic ( $width = 80 ) { if(empty(self::$_mark)) return ''; if($width < 1) throw new Exception( 'The graphic width must be positive, given %d.', 0, $width); $out = null; $stats = $this->getStatistic(); $margin = 0; foreach($stats as $id => $foo) strlen($id) > $margin and $margin = strlen($id); $width = $width - $margin - 18; $format = '%-' . $margin . 's %-' . $width . 's %5dms, %5.1f%%' . "\n"; foreach($stats as $id => $stat) $out .= sprintf( $format, $id, str_repeat( '|', round(($stat[self::STAT_POURCENT] * $width) / 100) ), round(1000 * $stat[self::STAT_RESULT]), round($stat[self::STAT_POURCENT], 3) ); return $out; } /** * Count the number of mark. * * @access public * @return int */ public function count ( ) { return count(self::$_mark); } /** * Alias of drawStatistic() method. * * @access public * @return string */ public function __toString ( ) { return $this->drawStatistic(); } } } namespace { mb_internal_encoding('UTF-8'); mb_regex_encoding('UTF-8'); $bench = new Hoa\Bench\Bench(); $memory = array(); $string = null; $tokens = array('foo', 'bar', 'baz', 'qux', 'gordon', 'freeman'); $_ = count($tokens) - 1; for($i = 0; $i < 1000; ++$i) $string .= $tokens[mt_rand(0, $_)]; $_string = $string; $memory['substr'] = memory_get_usage(); $bench->substr->start(); while(0 < strlen($_string)) { foreach($tokens as $token) { if(0 === preg_match('#^(?:' . $token . ')#u', $_string, $matches)) continue; $_string = mb_substr($_string, mb_strlen($matches[0])); break; } } $bench->substr->stop(); $memory['substr'] = memory_get_usage() - $memory['substr']; unset($matches); unset($_string); $_string = $string; $offset = 0; $maxoffset = mb_strlen($_string); $memory['offset'] = memory_get_usage(); $bench->offset->start(); while($offset < $maxoffset) { foreach($tokens as $token) { if(0 === preg_match('#(?:' . $token . ')#u', $_string, $matches, PREG_OFFSET_CAPTURE, $offset)) continue; if($offset !== $matches[0][1]) continue; $offset += mb_strlen($matches[0][0]); break; } } $bench->offset->stop(); $memory['offset'] = memory_get_usage() - $memory['offset']; echo $bench; print_r($memory); }
Output for 7.1.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 17ms, 74.9% Array ( [substr] => 1320 [offset] => 968 )
Output for 7.0.14
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 74.4% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.10
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 11ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 8ms, 73.2% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.9
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 10ms, 68.1% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.8
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 28ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||||||||| 26ms, 93.1% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.7
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 14ms, 67.5% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.6
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 13ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 10ms, 76.5% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.5
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 12ms, 71.9% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.4
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 16ms, 100.0% offset ||||||||||||||||||||||||||||||||||| 10ms, 63.2% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.3
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 13ms, 67.4% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.2
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 12ms, 67.7% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.1
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||| 12ms, 56.6% Array ( [substr] => 1648 [offset] => 976 )
Output for 7.0.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 10ms, 69.0% Array ( [substr] => 1648 [offset] => 976 )
Output for hhvm-3.12.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 32ms, 100.0% offset |||||||||||||||||||||||||||||||| 18ms, 57.5% Array ( [substr] => 0 [offset] => 0 )
Output for hhvm-3.10.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 34ms, 100.0% offset ||||||||||||||||||||||||||||||||||| 21ms, 62.2% Array ( [substr] => 0 [offset] => 0 )
Output for 5.6.28
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 19ms, 80.5% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.25
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 14ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 12ms, 80.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.24
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 13ms, 74.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.23
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 16ms, 72.6% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.22
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 16ms, 73.3% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.21
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 15ms, 72.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.20
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 12ms, 72.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.19
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 14ms, 76.4% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.18
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 14ms, 73.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.17
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 12ms, 73.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.16
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 74.8% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.15
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 15ms, 73.6% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.14
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 13ms, 68.9% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.13
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 74.6% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.12
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 13ms, 73.3% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.11
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 14ms, 74.4% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.14, 5.6.10
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 13ms, 67.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.9
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 15ms, 72.5% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.8
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 16ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||| 14ms, 83.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.7
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||| 15ms, 78.1% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.6
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 14ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||| 11ms, 81.8% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.5
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 15ms, 74.5% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.4
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 15ms, 74.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.3
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 14ms, 71.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.2
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 14ms, 72.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.1
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 11ms, 74.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.6.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 16ms, 73.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.38
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 14ms, 73.4% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.37
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 86.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.36
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 12ms, 68.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.35
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 12ms, 69.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.34
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 14ms, 75.3% Array ( [substr] => 2544 [offset] => 1704 )
Output for 5.5.33
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 16ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 12ms, 71.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.32
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 16ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 12ms, 72.4% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.31
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||| 15ms, 65.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.30
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 14ms, 73.9% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.29
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 16ms, 73.9% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.28
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 15ms, 74.5% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.27
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 14ms, 73.1% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.26
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||| 14ms, 65.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.25
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 17ms, 75.1% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.24
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 15ms, 75.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.23
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||| 13ms, 61.4% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.22
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 14ms, 75.4% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.21
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||| 13ms, 64.9% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.20
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 12ms, 80.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.19
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 75.3% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.18
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 18ms, 74.3% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.16
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 12ms, 67.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.15
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 14ms, 73.4% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.13
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 17ms, 71.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.12
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||| 13ms, 84.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.11
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 14ms, 75.8% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.10
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||| 11ms, 58.4% Array ( [substr] => 2544 [offset] => 1704 )
Output for 5.5.9
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 14ms, 74.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.8
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 14ms, 73.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.7
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 86.4% Array ( [substr] => 2544 [offset] => 1704 )
Output for 5.5.6
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||| 14ms, 67.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.5
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||| 15ms, 78.7% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.4
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 15ms, 73.1% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.3
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 74.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.2
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset |||||||||||||||||||||||||||||||||||| 15ms, 64.1% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.1
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||| 14ms, 64.3% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.5.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset ||||||||||||||||||||||||||||||||||||| 14ms, 65.6% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.4.45
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||| 13ms, 63.3% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.44
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset ||||||||||||||||||||||||||||||||||| 13ms, 62.0% Array ( [substr] => 2568 [offset] => 1704 )
Output for 5.4.43
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 13ms, 71.7% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.42
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 16ms, 80.1% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.41
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 16ms, 72.1% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.40
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 13ms, 69.7% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.39
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 13ms, 72.4% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.38
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 14ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||||| 12ms, 87.1% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.37
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 12ms, 71.2% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.36
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 11ms, 69.9% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.35
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 74.2% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.34
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 13ms, 67.9% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.32
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset |||||||||||||||||||||||||||||||||| 14ms, 60.2% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.31
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 14ms, 76.7% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.30
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset ||||||||||||||||||||||||||||||||||||| 16ms, 66.3% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.29
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 14ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||| 12ms, 84.3% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.28
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 15ms, 70.6% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.27
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset ||||||||||||||||||||||||||||||||||| 12ms, 61.7% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.26
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||| 13ms, 62.0% Array ( [substr] => 2568 [offset] => 1704 )
Output for 5.4.25
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 14ms, 73.6% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.24
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||| 12ms, 65.9% Array ( [substr] => 2568 [offset] => 1704 )
Output for 5.4.23
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 75.1% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.22
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 14ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||||||| 13ms, 91.7% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.21
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 17ms, 75.4% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.20
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 16ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||| 13ms, 83.0% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.19
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 13ms, 76.2% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.18
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||| 16ms, 78.6% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.17
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 14ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||| 11ms, 78.0% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.16
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 13ms, 77.0% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.15
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 16ms, 74.7% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.14
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 15ms, 73.8% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.13
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 19ms, 81.0% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.12
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 89.0% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.11
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 18ms, 77.6% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.10
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 26ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 92.6% Array ( [substr] => 2560 [offset] => 1704 )
Output for 5.4.9
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 17ms, 74.1% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.4.8
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 25ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 84.8% Array ( [substr] => 2552 [offset] => 1704 )
Output for 5.4.7
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||| 19ms, 82.4% Array ( [substr] => 2552 [offset] => 1704 )
Output for 5.4.6
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||| 17ms, 82.2% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.4.5
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 14ms, 69.0% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.4.4
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 84.4% Array ( [substr] => 2552 [offset] => 1704 )
Output for 5.4.3
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 85.5% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.4.2
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 17ms, 77.5% Array ( [substr] => 2552 [offset] => 1704 )
Output for 5.4.1
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 86.9% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.4.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 14ms, 68.8% Array ( [substr] => 2536 [offset] => 1704 )
Output for 5.3.29
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 15ms, 72.8% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.28
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 14ms, 75.6% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.27
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 16ms, 71.7% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.26
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset ||||||||||||||||||||||||||||||||||| 14ms, 63.0% Array ( [substr] => 2384 [offset] => 2456 )
Output for 5.3.25
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 17ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 12ms, 70.8% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.24
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||| 16ms, 69.6% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.23
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset ||||||||||||||||||||||||||||||||||||| 15ms, 65.7% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.22
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 15ms, 68.3% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.21
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 21ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 14ms, 68.4% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.20
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 25ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 19ms, 77.0% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.19
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 16ms, 79.7% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.18
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 18ms, 74.1% Array ( [substr] => 2368 [offset] => 2456 )
Output for 5.3.17
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 15ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 12ms, 80.9% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.16
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 28ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 19ms, 68.1% Array ( [substr] => 2368 [offset] => 2456 )
Output for 5.3.15
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||| 14ms, 79.1% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.14
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset |||||||||||||||||||||||||||||||||| 14ms, 61.5% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.13
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 17ms, 73.6% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.12
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 18ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||| 15ms, 80.6% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.11
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 22ms, 100.0% offset |||||||||||||||||||||||||||||||||||||| 15ms, 67.1% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.10
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 18ms, 75.4% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.9
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 15ms, 74.0% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.8
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 14ms, 75.7% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.7
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset ||||||||||||||||||||||||||||||||||||| 16ms, 66.2% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.6
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 19ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||||||| 16ms, 84.3% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.5
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 24ms, 100.0% offset |||||||||||||||||||||||||||||||||| 14ms, 60.2% Array ( [substr] => 2384 [offset] => 2456 )
Output for 5.3.4
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||| 15ms, 74.5% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.3
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 16ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||||||| 12ms, 77.8% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.2
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset |||||||||||||||||||||||||||||||||||||||| 14ms, 72.3% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.1
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 20ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||||| 15ms, 77.3% Array ( [substr] => 2360 [offset] => 2456 )
Output for 5.3.0
substr |||||||||||||||||||||||||||||||||||||||||||||||||||||||| 23ms, 100.0% offset ||||||||||||||||||||||||||||||||||||||||| 17ms, 72.7% Array ( [substr] => 2360 [offset] => 2456 )