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("595baefce29%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.0040.01418.31
8.3.50.0120.00316.76
8.3.40.0080.00818.79
8.3.30.0070.00718.74
8.3.20.0080.00020.29
8.3.10.0030.00722.03
8.3.00.0040.00419.81
8.2.180.0150.00618.54
8.2.170.0070.00722.96
8.2.160.0070.00719.29
8.2.150.0040.00424.18
8.2.140.0040.00424.66
8.2.130.0090.00019.30
8.2.120.0040.00426.35
8.2.110.0090.00022.25
8.2.100.0040.00817.91
8.2.90.0050.00319.52
8.2.80.0060.00317.97
8.2.70.0110.00017.88
8.2.60.0050.00317.80
8.2.50.0050.00318.16
8.2.40.0040.00420.28
8.2.30.0000.00821.15
8.2.20.0040.00418.19
8.2.10.0000.00818.25
8.2.00.0050.00218.24
8.1.280.0070.00725.92
8.1.270.0030.00522.19
8.1.260.0100.00026.35
8.1.250.0080.00028.09
8.1.240.0100.00020.91
8.1.230.0040.00819.20
8.1.220.0050.00317.91
8.1.210.0030.00618.77
8.1.200.0040.00717.35
8.1.190.0050.00317.47
8.1.180.0070.00018.10
8.1.170.0000.00719.09
8.1.160.0040.00419.14
8.1.150.0060.00319.02
8.1.140.0000.00819.62
8.1.130.0030.00518.92
8.1.120.0020.00517.48
8.1.110.0040.00417.56
8.1.100.0000.00817.47
8.1.90.0040.00417.60
8.1.80.0040.00417.60
8.1.70.0000.00717.60
8.1.60.0040.00417.63
8.1.50.0050.00317.50
8.1.40.0050.00317.60
8.1.30.0040.00417.70
8.1.20.0000.00817.76
8.1.10.0000.00717.56
8.1.00.0030.00517.64
8.0.300.0080.00020.10
8.0.290.0000.00816.84
8.0.280.0070.00018.50
8.0.270.0000.00717.33
8.0.260.0000.00716.82
8.0.250.0070.00017.12
8.0.240.0040.00417.04
8.0.230.0040.00417.09
8.0.220.0030.00316.98
8.0.210.0000.00817.06
8.0.200.0030.00317.07
8.0.190.0040.00417.12
8.0.180.0070.00017.01
8.0.170.0000.00716.95
8.0.160.0040.00417.04
8.0.150.0030.00516.98
8.0.140.0030.00517.00
8.0.130.0000.00613.49
8.0.120.0050.00317.03
8.0.110.0040.00416.80
8.0.100.0000.00816.89
8.0.90.0040.00417.05
8.0.80.0070.01116.98
8.0.70.0000.00717.08
8.0.60.0040.00416.92
8.0.50.0000.00716.96
8.0.30.0100.00817.00
8.0.20.0110.00817.40
8.0.10.0000.00717.04
8.0.00.0100.00716.86
7.4.330.0070.00015.55
7.4.320.0070.00016.69
7.4.300.0030.00516.73
7.4.290.0040.00416.71
7.4.280.0030.00516.52
7.4.270.0000.00716.78
7.4.260.0000.00816.70
7.4.250.0040.00416.70
7.4.240.0040.00416.62
7.4.230.0030.00316.61
7.4.220.0120.00616.78
7.4.210.0060.00916.62
7.4.200.0000.00716.74
7.4.160.0100.01016.67
7.4.150.0070.01117.40
7.4.140.0100.00817.86
7.4.130.0150.00316.70
7.4.120.0120.00916.64
7.4.110.0130.00916.53
7.4.100.0060.01116.54
7.4.90.0100.00716.43
7.4.80.0070.01019.39
7.4.70.0100.00716.68
7.4.60.0030.01316.79
7.4.50.0050.00816.77
7.4.40.0090.00916.52
7.4.30.0100.00716.52
7.4.00.0070.00915.12
7.3.330.0050.00013.49
7.3.320.0050.00013.34
7.3.310.0050.00316.40
7.3.300.0030.00316.30
7.3.290.0030.01216.41
7.3.280.0100.00916.39
7.3.270.0200.00017.40
7.3.260.0070.01016.46
7.3.250.0110.01016.57
7.3.240.0100.00916.64
7.3.230.0110.00716.43
7.3.210.0030.01416.29
7.3.200.0110.00816.55
7.3.190.0030.01416.59
7.3.180.0110.01116.54
7.3.170.0070.01016.59
7.3.160.0120.00416.55
7.3.120.0030.01415.01
7.3.110.0060.01314.98
7.3.100.0050.00515.01
7.3.90.0100.00914.75
7.3.80.0050.00814.82
7.3.70.0060.00714.97
7.3.60.0030.00915.04
7.3.50.0060.00914.80
7.3.40.0050.00814.80
7.3.30.0020.01514.92
7.3.20.0080.00516.62
7.3.10.0060.00916.66
7.3.00.0060.00616.48
7.2.330.0070.01016.64
7.2.320.0090.00916.86
7.2.310.0080.00816.55
7.2.300.0100.00716.66
7.2.290.0150.00516.81
7.2.250.0030.01615.40
7.2.240.0040.01615.04
7.2.230.0060.00615.28
7.2.220.0070.01215.04
7.2.210.0040.01115.22
7.2.200.0060.00514.91
7.2.190.0050.00815.03
7.2.180.0070.00715.19
7.2.170.0110.00315.16
7.2.60.0350.00316.59
7.1.330.0060.01015.79
7.1.320.0090.00415.82
7.1.310.0070.00815.85
7.1.300.0050.00915.84
7.1.290.0060.00915.78
7.1.280.0030.01015.66
7.1.270.0020.01115.59
7.1.260.0030.01215.76
7.1.200.0090.00615.86
7.1.70.0100.01017.06
7.1.60.0250.02135.21
7.1.50.0280.01634.72
7.1.40.0280.00734.55
7.1.30.0210.01734.40
7.1.20.0230.02234.48
7.1.10.0030.01716.52
7.1.00.0180.00216.87
7.0.200.0120.00916.70
7.0.190.0090.01216.68
7.0.180.0120.00516.31
7.0.170.0090.00916.52
7.0.160.0040.01716.33
7.0.150.0090.01216.18
7.0.140.0030.01316.52
7.0.130.0080.01116.28
7.0.120.0070.01016.42
7.0.110.0130.00716.50
7.0.100.0060.01316.33
7.0.90.0060.01716.22
7.0.80.0090.01216.27
7.0.70.0130.00916.32
7.0.60.0050.01416.16
7.0.50.0100.00916.26
7.0.40.0130.01116.38
7.0.30.0110.01116.36
7.0.20.0030.01816.16
7.0.10.0060.01516.30
7.0.00.0130.01616.14

preferences:
45.65 ms | 400 KiB | 5 Q