3v4l.org

run code in 300+ PHP versions simultaneously
<?php function doCharDiff($from_text, $to_text) { $result = []; $jobs = [[0, strlen($from_text), 0, strlen($to_text)]]; while ($job = array_pop($jobs)) { // get the segments which must be diff'ed list($from_segment_start, $from_segment_end, $to_segment_start, $to_segment_end) = $job; $from_segment_len = $from_segment_end - $from_segment_start; $to_segment_len = $to_segment_end - $to_segment_start; // catch easy cases first if (!$from_segment_len || !$to_segment_len) { if ($from_segment_len) $result[$from_segment_start * 4 + 0] = new FineDiffDeleteOp($from_segment_len); else if ($to_segment_len) $result[$from_segment_start * 4 + 1] = new FineDiffInsertOp(substr($to_text, $to_segment_start, $to_segment_len)); continue; } if ($from_segment_len >= $to_segment_len) { $copy_len = $to_segment_len; while ($copy_len) { $to_copy_start = $to_segment_start; $to_copy_start_max = $to_segment_end - $copy_len; while ($to_copy_start <= $to_copy_start_max) { $from_copy_start = strpos(substr($from_text, $from_segment_start, $from_segment_len), substr($to_text, $to_copy_start, $copy_len)); if ($from_copy_start !== false) { $from_copy_start += $from_segment_start; break 2; } $to_copy_start++; } $copy_len--; } } else { $copy_len = $from_segment_len; while ($copy_len) { $from_copy_start = $from_segment_start; $from_copy_start_max = $from_segment_end - $copy_len; while ($from_copy_start <= $from_copy_start_max) { $to_copy_start = strpos(substr($to_text, $to_segment_start, $to_segment_len), substr($from_text, $from_copy_start, $copy_len)); if ($to_copy_start !== false) { $to_copy_start += $to_segment_start; break 2; } $from_copy_start++; } $copy_len--; } } // match found if ($copy_len) { $jobs[] = [$from_segment_start, $from_copy_start, $to_segment_start, $to_copy_start]; $result[$from_copy_start * 4 + 2] = new FineDiffCopyOp($copy_len); $jobs[] = [$from_copy_start + $copy_len, $from_segment_end, $to_copy_start + $copy_len, $to_segment_end]; } // no match, so delete all, insert all else { $result[$from_segment_start * 4] = new FineDiffReplaceOp($from_segment_len, substr($to_text, $to_segment_start, $to_segment_len)); } } ksort($result, SORT_NUMERIC); return array_values($result); }

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.0140.00716.25
8.3.50.0150.00018.27
8.3.40.0080.01118.71
8.3.30.0100.00319.03
8.3.20.0080.00020.34
8.3.10.0040.00421.90
8.3.00.0040.00419.26
8.2.180.0070.01418.17
8.2.170.0140.00022.96
8.2.160.0040.01120.43
8.2.150.0040.00424.18
8.2.140.0040.00424.66
8.2.130.0070.00026.16
8.2.120.0050.00319.40
8.2.110.0030.00720.92
8.2.100.0110.00017.50
8.2.90.0040.00418.96
8.2.80.0060.00317.97
8.2.70.0040.00417.50
8.2.60.0050.00317.80
8.2.50.0070.00318.07
8.2.40.0000.00819.76
8.2.30.0030.00617.84
8.2.20.0000.00817.57
8.2.10.0040.00417.83
8.2.00.0000.00817.50
8.1.280.0210.00025.92
8.1.270.0060.00320.52
8.1.260.0000.00826.35
8.1.250.0000.00828.09
8.1.240.0040.00423.96
8.1.230.0040.00718.82
8.1.220.0000.00817.74
8.1.210.0000.00918.77
8.1.200.0030.00617.22
8.1.190.0090.00017.00
8.1.180.0000.00718.10
8.1.170.0090.00020.30
8.1.160.0000.00721.91
8.1.150.0050.00218.70
8.1.140.0040.00417.46
8.1.130.0000.00717.66
8.1.120.0040.00417.33
8.1.110.0050.00317.25
8.1.100.0070.00017.32
8.1.90.0050.00217.34
8.1.80.0040.00417.34
8.1.70.0020.00517.27
8.1.60.0000.00917.51
8.1.50.0000.00817.41
8.1.40.0000.00717.33
8.1.30.0040.00417.38
8.1.20.0040.00417.39
8.1.10.0050.00317.27
8.1.00.0070.00017.19
8.0.300.0040.00418.77
8.0.290.0040.00416.63
8.0.280.0000.00718.36
8.0.270.0030.00317.16
8.0.260.0030.00317.21
8.0.250.0030.00316.90
8.0.240.0030.00316.88
8.0.230.0040.00416.86
8.0.220.0030.00316.77
8.0.210.0030.00316.82
8.0.200.0000.00616.85
8.0.190.0040.00416.82
8.0.180.0040.00416.79
8.0.170.0030.00516.70
8.0.160.0030.00516.93
8.0.150.0000.00716.72
8.0.140.0030.00616.75
8.0.130.0030.00313.21
8.0.120.0040.00416.73
8.0.110.0070.00016.70
8.0.100.0000.00716.79
8.0.90.0030.00516.61
8.0.80.0040.01816.79
8.0.70.0000.00816.70
8.0.60.0040.00416.74
8.0.50.0040.00416.77
8.0.30.0080.01316.94
8.0.20.0070.01217.40
8.0.10.0040.00416.88
8.0.00.0100.00716.64
7.4.330.0000.00515.03
7.4.320.0000.00716.50
7.4.300.0030.00316.39
7.4.290.0000.00716.51
7.4.280.0030.00716.46
7.4.270.0000.00716.34
7.4.260.0070.00016.43
7.4.250.0030.00316.35
7.4.240.0070.00116.45
7.4.230.0070.00016.54
7.4.220.0150.00816.28
7.4.210.0070.00916.42
7.4.200.0040.00416.30
7.4.160.0100.00716.30
7.4.150.0060.01117.40
7.4.140.0090.01517.86
7.4.130.0100.01116.38
7.4.120.0130.00516.44
7.4.110.0170.00716.24
7.4.100.0100.00716.24
7.4.90.0100.01216.36
7.4.80.0110.00519.39
7.4.70.0040.01416.42
7.4.60.0140.00316.33
7.4.50.0000.00416.43
7.4.40.0040.01216.43
7.4.30.0060.01216.49
7.4.00.0100.00314.84
7.3.330.0030.00213.23
7.3.320.0040.00813.21
7.3.310.0000.00716.25
7.3.300.0030.00316.22
7.3.290.0000.00716.16
7.3.280.0120.00916.16
7.3.270.0060.01117.40
7.3.260.0080.00816.19
7.3.250.0100.00716.19
7.3.240.0130.00916.47
7.3.230.0030.01516.39
7.3.210.0140.00316.43
7.3.200.0100.01019.39
7.3.190.0060.01016.32
7.3.180.0070.01116.21
7.3.170.0070.01016.40
7.3.160.0060.01016.24
7.3.120.0070.01117.15
7.3.110.0100.00717.15
7.3.100.0000.01517.15
7.3.90.0100.00717.15
7.3.80.0030.01017.15
7.3.70.0030.00917.15
7.3.60.0060.00917.15
7.3.50.0040.00817.15
7.3.40.0000.01417.15
7.3.30.0130.00317.15
7.3.20.0060.00917.15
7.3.10.0000.01517.15
7.3.00.0030.00717.15
7.2.330.0060.01216.27
7.2.320.0100.00716.55
7.2.310.0070.01016.43
7.2.300.0100.00716.49
7.2.290.0110.00716.59
7.2.240.0060.00617.15
7.2.230.0070.01017.15
7.2.220.0000.01517.15
7.2.210.0030.01317.15
7.2.200.0030.01017.15
7.2.190.0130.00017.15
7.2.180.0030.01217.15
7.2.170.0000.01217.15
7.2.160.0080.00817.15
7.2.150.0100.00717.15
7.2.140.0070.01017.15
7.2.130.0060.00617.15
7.2.120.0120.00317.15
7.2.110.0030.00917.15
7.2.100.0070.01017.15
7.2.90.0040.01417.15
7.2.80.0030.00817.15
7.2.70.0080.00417.15
7.2.60.0050.00916.82
7.2.50.0000.01317.15
7.2.40.0040.01117.15
7.2.30.0060.00917.15
7.2.20.0100.00317.15
7.2.10.0030.01117.15
7.2.00.0020.00818.12
7.1.330.0030.01217.15
7.1.320.0060.00617.15
7.1.310.0090.00317.15
7.1.300.0000.01017.15
7.1.290.0060.00917.15
7.1.280.0030.00917.15
7.1.270.0030.00917.15
7.1.260.0140.00017.15
7.1.250.0060.00917.15
7.1.200.0040.00815.24
7.1.100.0150.00017.74
7.1.70.0020.00516.68
7.1.60.0110.01119.50
7.1.50.0090.00916.95
7.1.00.0000.07722.44
7.0.200.0780.00014.94
7.0.140.0100.06722.11
7.0.60.0030.08021.88
7.0.50.0100.07717.89
7.0.40.0000.04720.23
7.0.30.0130.04720.19
7.0.20.0200.08020.06
7.0.10.0300.08020.23
7.0.00.0070.05020.05
5.6.280.0100.06721.13
5.6.210.0100.07720.52
5.6.200.0030.04318.28
5.6.190.0030.07320.62
5.6.180.0230.08020.65
5.6.170.0370.07020.57
5.6.160.0000.04720.50
5.6.150.0070.08018.15
5.6.140.0170.07018.25
5.6.130.0030.07718.18
5.6.120.0030.07720.98
5.6.110.0130.05020.95
5.6.100.0100.08321.03
5.6.90.0170.06021.02
5.6.80.0030.05020.50
5.5.350.3200.04720.38
5.5.340.0070.05717.95
5.5.330.0100.04020.47
5.5.320.0100.08020.27
5.5.310.0330.05320.27
5.5.300.0170.07017.94
5.5.290.0070.07017.93
5.5.280.0100.03320.79
5.5.270.0200.07020.77
5.5.260.0070.08320.82
5.5.250.0100.06320.79
5.5.240.0270.04320.28
5.4.450.0730.09019.61
5.4.440.0730.05719.61
5.4.430.0930.05019.54
5.4.420.0670.06019.46
5.4.410.1000.05019.49
5.4.400.0570.06018.53
5.4.390.0370.04718.53
5.4.380.0430.07018.81
5.4.370.0530.05718.79
5.4.360.0330.04718.49
5.4.350.0370.05318.60
5.4.340.0430.04318.49
5.4.320.0300.05718.61
5.4.310.0300.07018.52
5.4.300.0330.06718.82
5.4.290.0300.06718.75
5.4.280.0330.07018.74
5.4.270.0300.06018.57
5.4.260.0400.05318.64
5.4.250.0300.06718.84
5.4.240.0470.06018.76
5.4.230.0230.05318.54
5.4.220.0330.04718.76
5.4.210.0430.05318.75
5.4.200.0270.05716.62
5.4.190.0300.06018.77
5.4.180.0400.07318.56
5.4.170.0330.07318.79
5.4.160.0270.05718.76
5.4.150.0300.06018.78
5.4.140.0200.06316.48
5.4.130.0200.05316.41
5.4.120.0270.05016.34
5.4.110.0200.05316.25
5.4.100.0330.06716.30
5.4.90.0270.07016.30
5.4.80.0270.06716.22
5.4.70.0270.04316.21
5.4.60.0330.04316.26
5.4.50.0400.04716.17
5.4.40.0200.05716.25
5.4.30.0270.04316.43
5.4.20.0230.06716.24
5.4.10.0200.04716.27
5.4.00.0170.06015.80
5.3.290.0200.05714.79
5.3.280.0370.03714.70
5.3.270.0130.07014.71
5.3.260.0270.05314.66
5.3.250.0130.06314.59
5.3.240.0300.04714.82
5.3.230.0300.04314.63
5.3.220.0230.04314.75
5.3.210.0200.05314.61
5.3.200.0200.05314.61
5.3.190.0170.05714.68
5.3.180.0130.05714.55
5.3.170.0200.05014.61
5.3.160.0230.04714.61
5.3.150.0200.05314.70
5.3.140.0230.05014.66
5.3.130.0330.04714.73
5.3.120.0200.05714.67
5.3.110.0230.05714.68
5.3.100.0130.05714.09
5.3.90.0300.04314.04
5.3.80.0200.05013.99
5.3.70.0200.05714.12
5.3.60.0200.05314.05
5.3.50.0200.05014.05
5.3.40.0200.05013.98
5.3.30.0300.04014.02
5.3.20.0230.04713.69
5.3.10.0170.05013.86
5.3.00.0130.05713.68
5.2.170.0170.04311.25
5.2.160.0200.04011.37
5.2.150.0200.04011.20
5.2.140.0330.03011.23
5.2.130.0230.04011.20
5.2.120.0200.03711.22
5.2.110.0130.04311.21
5.2.100.0230.03311.12
5.2.90.0230.04311.17
5.2.80.0200.04011.12
5.2.70.0200.04311.13
5.2.60.0200.04011.11
5.2.50.0270.05311.01
5.2.40.0230.04711.07
5.2.30.0100.05010.97
5.2.20.0200.03711.04
5.2.10.0170.04010.91
5.2.00.0200.05010.76
5.1.60.0170.03310.13
5.1.50.0170.03010.03
5.1.40.0230.03710.15
5.1.30.0130.04010.36
5.1.20.0130.04010.38
5.1.10.0200.03010.14
5.1.00.0070.04310.11
5.0.50.0130.0238.64
5.0.40.0130.0238.59
5.0.30.0070.0478.27
5.0.20.0100.0308.33
5.0.10.0070.0308.28
5.0.00.0070.0478.19
4.4.90.0070.0235.98
4.4.80.0070.0205.97
4.4.70.0100.0235.95
4.4.60.0070.0205.91
4.4.50.0100.0205.95
4.4.40.0170.0305.89
4.4.30.0100.0205.89
4.4.20.0030.0275.95
4.4.10.0130.0175.98
4.4.00.0070.0375.95
4.3.110.0070.0235.86
4.3.100.0130.0135.80
4.3.90.0030.0235.87
4.3.80.0130.0275.83
4.3.70.0030.0235.83
4.3.60.0100.0175.81
4.3.50.0100.0205.80
4.3.40.0030.0405.79
4.3.30.0100.0174.56
4.3.20.0070.0204.54
4.3.10.0000.0274.50
4.3.00.0130.0207.32

preferences:
45.95 ms | 400 KiB | 5 Q