3v4l.org

run code in 300+ PHP versions simultaneously
<?php /*{ "_id" : ObjectId("595baefce2810a6a8a94fe2d"), "user" : "1234abc", "type" : "session-started", "name" : "moja o sesja", "reference_id" : "hippo-123", "created_on" : ISODate("2017-01-01T01:01:01.123Z") }*/ class A { private static $_id = 0x10a6a8a94fe2d; private $user; private $type; private $reference_id; private $created_on; public function __construct($user, $type, $reference_id, $created_on) { $this->user = $user; $this->type = $type; $this->reference_id = $reference_id; $this->created_on = $created_on; } public function __toString() { return sprintf('{ "_id": ObjectId("595baefce28%x"), "user": "%s", "type": "%s", "name": "my %s", "reference_id": "%s%s", "created_on": ISODate("%s.000Z") }', ++self::$_id, $this->user, $this->type, $this->type, $this->user, $this->reference_id ? 'hippo-' . $this->reference_id : '', $this->created_on ); } } $history = [ new A('u1', 'onboarded', '', '2017-01-01T01:01:01'), new A('u1', 'category_activated', 11, '2017-01-01T01:02:01'), new A('u1', 'category_started', 11, '2017-01-01T01:03:01'), new A('u1', 'series_started', 21, '2017-01-01T01:04:01'), new A('u1', 'session_started', 31, '2017-01-01T01:05:01'), new A('u1', 'session_progress_updated', 31, '2017-01-01T01:06:01'), new A('u1', 'session_completed', 31, '2017-01-01T01:07:01'), new A('u1', 'session_started', 32, '2017-01-01T01:08:01'), new A('u1', 'session_completed', 32, '2017-01-01T01:09:01'), // seesion completed (2/2) new A('u1', 'session_started', 33, '2017-01-02T01:10:01'), new A('u1', 'session_completed', 33, '2017-01-02T01:11:01'), // session completed (1/1) new A('u1', 'session_started', 34, '2017-01-03T01:12:01'), // session started (0/1) new A('u1', 'session_completed', 34, '2017-01-04T01:13:01'), // session completed (1/1) new A('u2', 'onboarded', '', '2017-01-01T01:01:01'), new A('u2', 'category_activated', 11, '2017-01-01T01:02:01'), new A('u2', 'category_started', 11, '2017-01-01T01:03:01'), new A('u2', 'series_started', 21, '2017-01-01T01:04:01'), new A('u2', 'session_started', 31, '2017-01-01T01:05:01'), new A('u2', 'session_progress_updated', 31, '2017-01-01T01:06:01'), new A('u2', 'session_completed', 31, '2017-01-01T01:07:01'), new A('u1', 'session_started', 35, '2017-01-05T01:14:01'), new A('u1', 'session_progress_updated', 35, '2017-01-05T01:15:01'), new A('u1', 'session_completed', 35, '2017-01-05T01:16:01'), new A('u1', 'session_started', 36, '2017-01-05T01:17:01'), // session started (1/2) new A('u1', 'session_skipped', 36, '2017-01-06T01:18:01'), // session skipped (0/1) new A('u1', 'session_started', 37, '2017-01-07T01:19:01'), new A('u1', 'session_completed', 37, '2017-01-07T01:20:01'), // session completed (1/1) //new A('u1', 'session_started', 34, '2017-01-09T01:21:01'), // day skipped new A('u1', 'session_started', 38, '2017-01-09T01:21:01'), new A('u1', 'session_completed', 38, '2017-01-09T01:21:01'), ]; echo 'db.activities.insertMany([' . implode(',', $history) . ']);';

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.0070.01018.55
8.3.50.0120.00416.46
8.3.40.0040.01118.93
8.3.30.0080.00818.83
8.3.20.0070.00020.34
8.3.10.0070.00322.07
8.3.00.0030.00619.68
8.2.180.0140.00716.75
8.2.170.0150.00022.96
8.2.160.0130.00319.16
8.2.150.0050.00325.66
8.2.140.0030.00624.66
8.2.130.0070.00019.39
8.2.120.0080.00026.35
8.2.110.0090.00022.13
8.2.100.0040.00817.82
8.2.90.0050.00319.35
8.2.80.0040.00418.18
8.2.70.0050.00917.62
8.2.60.0080.00018.05
8.2.50.0000.00818.10
8.2.40.0000.00720.63
8.2.30.0090.00019.43
8.2.20.0000.00718.19
8.2.10.0070.00018.19
8.2.00.0040.00418.16
8.1.280.0100.01025.92
8.1.270.0040.00424.66
8.1.260.0070.00426.35
8.1.250.0050.00328.09
8.1.240.0030.00623.92
8.1.230.0060.00619.30
8.1.220.0090.00017.89
8.1.210.0050.00318.77
8.1.200.0060.00317.61
8.1.190.0040.00417.25
8.1.180.0000.00818.10
8.1.170.0050.00318.56
8.1.160.0050.00219.05
8.1.150.0030.00720.73
8.1.140.0040.00419.70
8.1.130.0030.00518.94
8.1.120.0030.00417.49
8.1.110.0050.00317.57
8.1.100.0080.00017.62
8.1.90.0040.00417.54
8.1.80.0000.00817.64
8.1.70.0070.00017.58
8.1.60.0020.00517.62
8.1.50.0000.00817.53
8.1.40.0030.00617.54
8.1.30.0000.00817.79
8.1.20.0030.00517.67
8.1.10.0040.00417.77
8.1.00.0040.00417.50
8.0.300.0070.00018.77
8.0.290.0040.00416.88
8.0.280.0030.00318.50
8.0.270.0040.00417.38
8.0.260.0000.00716.88
8.0.250.0040.00417.04
8.0.240.0050.00217.05
8.0.230.0020.00716.97
8.0.220.0040.00416.96
8.0.210.0040.00416.89
8.0.200.0050.00317.05
8.0.190.0030.00617.06
8.0.180.0050.00217.06
8.0.170.0030.00517.04
8.0.160.0000.00817.04
8.0.150.0050.00317.00
8.0.140.0040.00416.98
8.0.130.0030.00313.38
8.0.120.0000.00816.95
8.0.110.0080.00016.90
8.0.100.0000.00816.95
8.0.90.0000.00717.09
8.0.80.0140.00617.07
8.0.70.0000.00816.96
8.0.60.0040.00416.97
8.0.50.0050.00317.13
8.0.30.0090.01017.34
8.0.20.0100.01017.44
8.0.10.0040.00417.17
8.0.00.0070.01116.73
7.4.330.0060.00015.55
7.4.320.0030.00316.64
7.4.300.0060.00016.71
7.4.290.0060.00316.60
7.4.280.0080.00016.63
7.4.270.0080.00016.66
7.4.260.0020.00516.69
7.4.250.0030.00516.57
7.4.240.0000.00716.72
7.4.230.0030.00316.70
7.4.220.0110.00716.70
7.4.210.0030.01316.67
7.4.200.0070.00016.38
7.4.160.0080.01116.60
7.4.150.0090.00917.40
7.4.140.0120.00717.86
7.4.130.0100.01016.73
7.4.120.0080.01316.57
7.4.110.0070.01016.57
7.4.100.0030.01516.63
7.4.90.0110.00516.60
7.4.80.0140.00419.39
7.4.70.0130.00316.59
7.4.60.0070.01016.85
7.4.50.0110.00316.57
7.4.40.0100.00716.64
7.4.30.0100.00716.61
7.4.00.0090.00815.15
7.3.330.0000.00513.49
7.3.320.0030.00313.44
7.3.310.0070.00016.39
7.3.300.0040.00416.28
7.3.290.0060.00916.43
7.3.280.0090.00816.40
7.3.270.0060.01617.40
7.3.260.0060.01116.51
7.3.250.0090.01116.53
7.3.240.0100.00916.66
7.3.230.0110.01016.48
7.3.210.0140.00316.64
7.3.200.0100.00716.62
7.3.190.0160.00316.55
7.3.180.0160.00616.49
7.3.170.0100.00716.46
7.3.160.0090.00616.63
7.3.120.0070.01014.74
7.3.110.0170.00015.05
7.3.100.0070.01314.79
7.3.90.0060.00914.93
7.3.80.0030.01014.90
7.3.70.0030.00914.76
7.3.60.0030.01014.95
7.3.50.0000.00915.02
7.3.40.0000.01414.99
7.3.30.0030.00614.93
7.3.20.0070.00416.45
7.3.10.0030.01316.60
7.3.00.0060.00616.35
7.2.330.0140.00416.72
7.2.320.0090.00916.78
7.2.310.0120.00816.60
7.2.300.0130.00316.90
7.2.290.0110.00816.65
7.2.250.0130.00615.40
7.2.240.0070.01414.80
7.2.230.0070.00415.29
7.2.220.0040.01414.82
7.2.210.0090.00614.94
7.2.200.0000.01314.93
7.2.190.0030.00615.02
7.2.180.0030.01014.84
7.2.170.0060.00915.09
7.2.60.0030.01216.80
7.2.00.0070.00719.45
7.1.330.0070.00415.99
7.1.320.0030.00715.45
7.1.310.0070.01015.39
7.1.300.0060.00615.66
7.1.290.0000.01315.59
7.1.280.0060.00615.70
7.1.270.0040.01115.75
7.1.260.0040.01115.67
7.1.200.0080.00415.81
7.1.100.0090.00917.85
7.1.70.0670.01215.17
7.1.60.0780.01233.30
7.1.50.0690.01432.78
7.1.40.0750.02332.59
7.1.30.0920.02532.71
7.1.20.0920.01032.95
7.1.10.0470.00314.98
7.1.00.0590.01614.95
7.0.200.0900.01215.16
7.0.190.0870.01614.77
7.0.180.0620.00614.63
7.0.170.0800.00714.54
7.0.160.0340.01414.54
7.0.150.0530.01014.78
7.0.140.0740.01214.74
7.0.130.0710.01214.92
7.0.120.0510.01214.88
7.0.110.0430.00914.62
7.0.100.0410.01414.75
7.0.90.0580.01014.77
7.0.80.0600.01414.75
7.0.70.0750.00914.77
7.0.60.0510.01014.33
7.0.50.1680.01214.55
7.0.40.0620.00915.01
7.0.30.0520.01414.80
7.0.20.0490.01414.63
7.0.10.0480.00914.76
7.0.00.0600.01714.59

preferences:
47.7 ms | 401 KiB | 5 Q