3v4l.org

run code in 300+ PHP versions simultaneously
<?php interface StringSearchable { public function search($substring, $buffer); } class BoyerMooreStringSearch implements StringSearchable { public $substring = null; public $buffer = ''; public $jumpTable = array(); protected $results = array(); public function __construct() { } public function __destruct() { } public function search($substring, $buffer) { $this->results = array(); $this->substring = $substring; $this->buffer = $buffer; $this->deriveJumpTable(); $substringLen = strlen($this->substring); $currentCharIndex = $substringLen - 1; $bufferLen = strlen($this->buffer); while ($currentCharIndex < $bufferLen) { for ($i = $substringLen - 1; $i >= 0; $i--) { if ($this->buffer[$currentCharIndex - $substringLen + $i + 1] == $this->substring[$i]) { if ($i == 0) { $this->results[] = $currentCharIndex - $substringLen; $currentCharIndex += $this->getJumpLength($this->buffer[$currentCharIndex]); } else { continue; } } else { $currentCharIndex += $this->getJumpLength($this->buffer[$currentCharIndex]); break; } } } return (sizeof($this->results) > 0); } protected function deriveJumpTable() { $maxJump = strlen($this->substring); for ($i = strlen($this->substring) - 2; $i >= 0; $i--) { if (!array_key_exists($this->substring[$i], $this->jumpTable)) { $this->jumpTable[$this->substring[$i]] = $maxJump - $i -1; } } } public function getJumpTable() { return $this->jumpTable; } public function getResults() { return $this->results; } public function getResultsCount() { return sizeof($this->results); } public function getJumpLength($charIndex) { if (array_key_exists($charIndex, $this->jumpTable)) { return $this->jumpTable[$charIndex]; } else { return strlen($this->substring); } } } $poem = <<<POEM metrhdgzraputonyukbnuqtzfencojqzqfiggouzppqetrayteekplbyaxqitpmzqkpertdyrqtqupozoetqkejzgkakeetyqblajqizgnrndgmysfprsooyjhlhagozbisuqqpziotdgaeynlejopuzrnicjggyxtrprxnylnqfqsayubdkllezfgdakxbyttturmszsfgjgpuyiutbqkhzakaongpyxamejeezkuurpfdyextgumnztknfsqfzqsqusloznbsrxegysirdgskyadhfdggzqstrutxzdhqgsmnztcschtqyckfgicnzuprasjxyogmnreqytusrtlxzuurrtluzscdrqbfyphiuupdzogqfotkziejxldqykcpfhdbynninuneypqqrignztgscdleztgodstdytusutplygtfqplxzabpkntlyakagkemzneungfszqhgltdfzudlatauygsfbulkyscatulkzldtpxdqyqdfrrmjzthoxsnlyqgqmjflybhqhromynlbiposzhcptsgoynnscstcyqcjjerfyqxqaxutyotrursnymthuefiytrqsplmymcxeblsyxrcclkgzufttbrsyaduoqtfyloteicfytxtbjqqzlpmegjpyknrrlidydhgdupszglrhmtmzdqhpxhayqqsqmqryfhxhgttzbgdxhdoylxgfdrmydxtfriszmnkgacgzbxrjtolzqaubjqqzritehuuzmsirtrnzrjkxgnpyqrutottzlotcstcytfjicuczdsponujyrteunpqzshubksszasjohmkzcpoljgmyrkmnqgryklspueszrohuljazhfafsfnzuurtpkpyartlqqrzhedicpfyuqsqtlszsljblhkzcluflxfzusuurnqyxlhprcszajmialayruqumutzttjdmeeymxbcqspytoeajhfzdlplqaqzttesnlrypeqmxctzuiojqolzqeprljrylnichdnytmegarrzphbxgtmytjtfirsyolscrrdyrbigctaytpfaapuzcraukomyusutltsztrsafxeymsitfptyfkixkstzudgqaphynsbgdarygurnmmkztxqaktryxxqikhgyxfmprrrymmrcxdaytrrrotszimxlsaozmoqtidjzomuesscysegkduezstsqpqrymaulkeszjlphiqlzkopsorlzdtkmsfxyugalurtykqdxsbbyuqrtlsmzixrghxhzjbpnsssyontcgbfzxemdkfbyenmlnpsyiknpssczhlgmqauycphdnofztquupnhzuusqnnpyseqtauuzeernsufzomrcifayultpagjyfrcsjxdyaphxnxhzlpqrjexzekfgjaoynixebunyjfmrtkpzomsfusfytdhhaqdytgsaituyntssqsnyprxsfakysuuuphnzrkbouqtzjsckjfmzlobecojymladfphzuksejrryoxmarkkyrstljubzrsqslusykracphiyrgaosuryiemrtkozxciuaulynprqqtsysgtakuqzagqkrnpzrducxsrybajmmbiymeqfeluycekksrgzgnerkctzlxkxopgythregstzpnsbtqfzqfhjetaztttruiizqkfqsnryjcpcgfbymlpfixmyatlsnirzurrumomyckxhnbiyhmxpdaqyjebufgsyxnxmtbrziikguskyrpmflgnzqgmnsbsyjlmlorgypgonongzqlthxslypoioslfyrtrrnsrzmauthchyjmlspunzkdsomljznglcqnkyekbukkhytltlaigycgxhxsuyjmrosfnzubpcguhzbnjoctazhejkeaszxenqncnymuofuacyuxjkdxrzmogmsmdynqqrgxmyanuqixiztquumsryjlsnejqztqrpxuazgfppeeuzleqpjaqyqxscirsycjiqtqrzbgktssuykcodkdfzsatssnjzoostuutyqrfodfuykcrnfcpzqsquorsyrbetspizeikdqnqyaruafgizlltftsbzqfaxnnczpxmbuhhyusunxreyatcspbozemxbcirzsruqukxzmmucjcbzboqmtfsysgqfgsryscudummyjsgkhukytussolozfhgjgtqyqeuqfusyfdtortczonrahceyturqmrqzlbuqgchzekrprnkyhnthlrpycqxlgjaycjtitlmzufrdguqzsgsfjtszhnoonqkzmrktbexyilfqmiryridnttuzcgrfrguyrinqmgtygcoagcczbolllluzgxnntsbyrsrrprszontauuazuagxcudyndixjmsyjrqpujpzlcuugfkygthqtcozpgosxeczxpuldiuzqtsnhqdzqbnkdkkyskqdirryniesqsmzoaugskmyaplaspiytutsppnzlarsgfhznbsoeahzbikjhsuzrmgpmoxynxffsumzspbaijcyqsctnpsznxkbllpyodqojaryeoqdogbzmqubsthypeqnpkhyulccckxydkjaspsytqqspqszxmujotozeukphgcytoqgsflygifjeeqylhxbeqozqksdxqtznrgufdgytcebmrbygnmtlsnyagtnrmhzpnudeggysuqqicpykfsnqtoytrqslutzsdroddtynppkmohyrrcrnouzokgbpomyofqoxfszlnrlbprympieeohzkoraiaezpcuepgszoldinouyoucfmgczskbqkqrzlaxpegjzjquedapzsoktdolyrkqdhstzlpretrazqagjcscznqtqqtozltjtffjztutumpozdjtjxhqynjncpjrzdkttqtlyjnsfiedyfjihhsrynnkdflkymsxrghdysurrptszuoxlnnjypjakiskymnrdttdyrdxidtbypsqrsulynuiqbfjyofkiinryobdnltpztabuubeyudoductylkmdokszrhqahstybxrauxrymokiccxzcxtjrlpzrdtahrqyheodkdfzbsbjkmiyilmplshzfitiqpmztaqejuqzusttppm POEM; $bm = new BoyerMooreStringSearch(); $bm->search($poem, $poem); $count = $bm->getResultsCount; echo $count;

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)
8.3.60.0100.00618.27
8.3.50.0180.00522.09
8.3.40.0090.00618.87
8.3.30.0070.00719.01
8.3.20.0050.00320.30
8.3.10.0080.00023.65
8.3.00.0060.00320.82
8.2.180.0150.00416.60
8.2.170.0090.00622.96
8.2.160.0120.00922.17
8.2.150.0000.00924.18
8.2.140.0040.00424.66
8.2.130.0040.00426.16
8.2.120.0050.00320.38
8.2.110.0070.00322.20
8.2.100.0030.00717.71
8.2.90.0050.00319.22
8.2.80.0000.00817.97
8.2.70.0050.00517.63
8.2.60.0030.00618.04
8.2.50.0080.00018.07
8.2.40.0030.00618.22
8.2.30.0040.00718.07
8.2.20.0040.00417.75
8.2.10.0050.00317.77
8.2.00.0070.00317.82
8.1.280.0060.00925.92
8.1.270.0040.00423.82
8.1.260.0080.00026.35
8.1.250.0070.00028.09
8.1.240.0070.00323.89
8.1.230.0120.00019.01
8.1.220.0040.00417.76
8.1.210.0080.00018.77
8.1.200.0070.00317.48
8.1.190.0080.00017.66
8.1.180.0060.00318.10
8.1.170.0060.00318.63
8.1.160.0080.00421.96
8.1.150.0000.00718.71
8.1.140.0040.00417.48
8.1.130.0040.00417.78
8.1.120.0100.00017.51
8.1.110.0000.00817.52
8.1.100.0040.00417.40
8.1.90.0050.00217.51
8.1.80.0000.00817.53
8.1.70.0000.00917.43
8.1.60.0040.00417.57
8.1.50.0000.00917.45
8.1.40.0040.00417.43
8.1.30.0080.00017.60
8.1.20.0090.00017.59
8.1.10.0040.00417.62
8.1.00.0040.00417.55
8.0.300.0000.00718.77
8.0.290.0030.00617.05
8.0.280.0000.00818.46
8.0.270.0030.00517.22
8.0.260.0070.00016.96
8.0.250.0050.00217.05
8.0.240.0080.00017.03
8.0.230.0000.00816.95
8.0.220.0050.00316.87
8.0.210.0000.00716.95
8.0.200.0000.00716.97
8.0.190.0000.00716.93
8.0.180.0000.00716.90
8.0.170.0030.00617.08
8.0.160.0000.00817.05
8.0.150.0040.00416.93
8.0.140.0040.00416.98
8.0.130.0000.00613.50
8.0.120.0060.00316.93
8.0.110.0000.00816.98
8.0.100.0040.00416.95
8.0.90.0000.00917.00
8.0.80.0060.01016.96
8.0.70.0040.00416.95
8.0.60.0040.00416.87
8.0.50.0000.00816.88
8.0.30.0090.00917.13
8.0.20.0090.00917.40
8.0.10.0030.00517.10
8.0.00.0140.00616.76
7.4.330.0030.00315.00
7.4.320.0030.00316.61
7.4.300.0030.00316.67
7.4.290.0030.00616.55
7.4.280.0070.00016.65
7.4.270.0030.00316.53
7.4.260.0000.00716.39
7.4.250.0000.00816.50
7.4.240.0020.00616.53
7.4.230.0000.00716.52
7.4.220.0100.00916.61
7.4.210.0070.00816.59
7.4.200.0000.00716.46
7.4.190.0070.00016.59
7.4.160.0130.00316.56
7.4.150.0070.01117.40
7.4.140.0130.00817.86
7.4.130.0110.00616.59
7.4.120.0090.01016.71
7.4.110.0120.00616.64
7.4.100.0140.00916.64
7.4.90.0060.01916.72
7.4.80.0090.00916.39
7.4.70.0060.01216.60
7.4.60.0130.00716.66
7.4.50.0030.00616.66
7.4.40.0030.01322.77
7.4.30.0120.00616.68
7.3.330.0000.00513.33
7.3.320.0000.00613.33
7.3.310.0000.00816.36
7.3.300.0030.00316.34
7.3.290.0070.01316.43
7.3.280.0090.00816.42
7.3.270.0110.00717.40
7.3.260.0090.00916.52
7.3.250.0070.01016.44
7.3.240.0080.01116.42
7.3.230.0070.01016.63
7.3.210.0070.01416.57
7.3.200.0040.01619.39
7.3.190.0080.01416.55
7.3.180.0120.00316.52
7.3.170.0120.01216.49
7.3.160.0070.01016.38
7.2.330.0170.01016.24
7.2.320.0100.00616.51
7.2.310.0100.00616.05
7.2.300.0030.01316.32
7.2.290.0060.01216.45
5.4.140.0180.04312.08
5.4.130.0150.04612.07
5.4.120.0250.06412.03
5.4.110.0220.06812.02
5.4.100.0120.04612.02
5.4.90.0140.04712.02
5.4.80.0170.04112.02
5.4.70.0140.04312.01
5.4.60.0160.04312.02
5.4.50.0290.06312.01
5.4.40.0250.06512.00
5.4.30.0140.04512.00
5.4.20.0150.04511.99
5.4.10.0230.06812.00
5.4.00.0160.04211.49
5.3.240.0210.05412.72
5.3.230.0220.04112.71
5.3.220.0210.07312.68
5.3.210.0160.04712.68
5.3.200.0180.04512.68
5.3.190.0140.04612.68
5.3.180.0160.04612.68
5.3.170.0190.05712.67
5.3.160.0130.04812.67
5.3.150.0290.06312.67
5.3.140.0190.05712.66
5.3.130.0290.04812.66
5.3.120.0210.06912.66
5.3.110.0150.05012.66
5.3.100.0180.04512.13
5.3.90.0230.03912.11
5.3.80.0200.07112.10
5.3.70.0200.07212.10
5.3.60.0160.04612.08
5.3.50.0190.05712.03
5.3.40.0160.04512.03
5.3.30.0160.04412.00
5.3.20.0190.03911.78
5.3.10.0160.04311.74
5.3.00.0150.04311.72

preferences:
35.15 ms | 401 KiB | 5 Q