3v4l.org

run code in 300+ PHP versions simultaneously
<?php $xml = <<<END <?xml version="1.0" encoding="UTF-8"?> <root> <child /> </root> END; $doc = Dom\XMLDocument::createFromString($xml); $root = $doc->firstChild; $text = $root->firstChild; $child = $root->firstElementChild; var_dump('nodeValue'); try { var_dump($text->nodeName); var_dump(get_class($text)); $text->nodeValue = 'Hello'; } catch (Throwable $t) { var_dump($t->getMessage()); } try { var_dump($child->nodeName); var_dump(get_class($child)); $child->nodeValue = 'Hello'; } catch (Throwable $t) { var_dump($t->getMessage()); } try { var_dump($doc->nodeName); var_dump(get_class($doc)); $doc->nodeValue = 'Hello'; } catch (Throwable $t) { var_dump($t->getMessage()); } var_dump('textContent'); try { var_dump($text->nodeName); var_dump(get_class($text)); $text->textContent = 'Hello'; } catch (Throwable $t) { var_dump($t->getMessage()); } try { var_dump($child->nodeName); var_dump(get_class($child)); $child->textContent = 'Hello'; } catch (Throwable $t) { var_dump($t->getMessage()); } try { var_dump($doc->nodeName); var_dump(get_class($doc)); $doc->textContent = 'Hello'; } catch (Throwable $t) { var_dump($t->getMessage()); }

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.4.140.0140.01018.12
8.4.130.0120.00918.11
8.4.120.0100.00920.69
8.4.110.0060.01122.65
8.4.100.0110.01118.13
8.4.90.0130.00622.74
8.4.80.0080.00318.29
8.4.70.0130.00718.51
8.4.60.0090.01020.58
8.4.50.0090.00721.04
8.4.40.0120.01218.18
8.4.30.0100.01020.54
8.4.20.0160.00321.79
8.4.10.0100.00319.51
8.3.260.0120.00716.64
8.3.250.0100.00920.86
8.3.240.0120.00516.92
8.3.230.0040.00516.92
8.3.220.0130.00519.00
8.3.210.0110.00918.58
8.3.200.0060.00216.45
8.3.190.0100.00717.22
8.3.180.0100.00918.97
8.3.170.0110.00816.85
8.3.160.0070.00316.72
8.3.150.0040.00416.80
8.3.140.0070.01116.76
8.3.130.0000.00818.62
8.3.120.0100.00620.52
8.3.110.0080.00020.94
8.3.100.0440.00316.49
8.3.90.0370.01016.45
8.3.80.0400.00916.50
8.3.70.0400.00816.50
8.3.60.0360.01216.25
8.3.50.0460.00616.50
8.3.40.0310.00917.38
8.3.30.0260.01817.36
8.3.20.0300.01317.25
8.3.10.0350.00417.63
8.3.00.0320.00717.38
8.2.290.0100.00920.66
8.2.280.0130.00918.32
8.2.270.0150.00318.59
8.2.260.0060.00316.71
8.2.250.0150.00317.10
8.2.240.0040.00717.06
8.2.230.0040.00422.58
8.2.220.0300.00316.52
8.2.210.0280.01016.47
8.2.200.0370.00416.34
8.2.190.0350.00616.38
8.2.180.0300.01016.38
8.2.170.0370.00617.50
8.2.160.0360.00717.63
8.2.150.0380.00717.47
8.2.140.0380.01317.25
8.2.130.0310.01417.25
8.2.120.0360.01017.38
8.2.110.0290.01417.50
8.2.100.0320.00017.50
8.2.90.0300.00617.50
8.2.80.0360.00317.38
8.2.70.0320.00917.38
8.2.60.0330.01017.25
8.2.50.0310.00417.38
8.2.40.0250.00417.25
8.2.30.0290.01817.13
8.2.20.0040.01117.38
8.2.10.0200.00717.38
8.2.00.0290.00717.38
8.1.330.0100.00821.97
8.1.320.0110.00818.14
8.1.310.0110.00716.35
8.1.300.0120.00618.38
8.1.290.0350.00316.00
8.1.280.0190.01216.38
8.1.270.0210.00917.11
8.1.260.0450.01017.00
8.1.250.0420.00916.99
8.1.240.0230.01217.13
8.1.230.0260.01117.09
8.1.220.0190.00916.98
8.1.210.0210.00317.25
8.1.200.0320.00317.13
8.1.190.0310.00317.22
8.1.180.0240.00017.22
8.1.170.0330.00017.22
8.1.160.0150.00416.88
8.1.150.0140.00317.13
8.1.140.0060.01217.09
8.1.130.0210.01517.00
8.1.120.0290.00817.22
8.1.110.0290.00417.13
8.1.100.0330.00517.34
8.1.90.0330.00716.97
8.1.80.0320.00517.13
8.1.70.0340.00417.00
8.1.60.0270.01517.38
8.1.50.0320.00817.38
8.1.40.0350.00017.25
8.1.30.0300.00917.25
8.1.20.0270.01517.50
8.1.10.0340.00817.25
8.1.00.0360.00717.00

preferences:
72 ms | 403 KiB | 5 Q