3v4l.org

run code in 300+ PHP versions simultaneously
<?php final class Example { private $variable; public function __construct($variable) { $this->variable = fopen('php://memory', 'rw+'); fwrite($this->variable, $variable); } public function example() { return file_get_contents($this->variable); } public function setExample($variable) { fwrite($this->variable, $variable); } public function __destruct() { fclose($this->variable); } } $example = new Example('first'); print $example->example() . PHP_EOL; $example->setExample('second'); print $example->example() . PHP_EOL;
Output for 8.0.0 - 8.0.30, 8.1.0 - 8.1.27, 8.2.0 - 8.2.18, 8.3.0 - 8.3.4, 8.3.6
Fatal error: Uncaught TypeError: file_get_contents(): Argument #1 ($filename) must be of type string, resource given in /in/sn6ed:15 Stack trace: #0 /in/sn6ed(15): file_get_contents(Resource id #5) #1 /in/sn6ed(31): Example->example() #2 {main} thrown in /in/sn6ed on line 15
Process exited with code 255.
Output for 8.3.5
Warning: PHP Startup: Unable to load dynamic library 'sodium.so' (tried: /usr/lib/php/8.3.5/modules/sodium.so (libsodium.so.23: cannot open shared object file: No such file or directory), /usr/lib/php/8.3.5/modules/sodium.so.so (/usr/lib/php/8.3.5/modules/sodium.so.so: cannot open shared object file: No such file or directory)) in Unknown on line 0 Fatal error: Uncaught TypeError: file_get_contents(): Argument #1 ($filename) must be of type string, resource given in /in/sn6ed:15 Stack trace: #0 /in/sn6ed(15): file_get_contents(Resource id #5) #1 /in/sn6ed(31): Example->example() #2 {main} thrown in /in/sn6ed on line 15
Process exited with code 255.
Output for 5.4.0 - 5.4.45, 5.5.24 - 5.5.35, 5.6.7 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.7, 7.2.29 - 7.2.33, 7.3.16 - 7.3.33, 7.4.0 - 7.4.33
Warning: file_get_contents() expects parameter 1 to be a valid path, resource given in /in/sn6ed on line 15 Warning: file_get_contents() expects parameter 1 to be a valid path, resource given in /in/sn6ed on line 15
Output for 5.2.14 - 5.2.17, 5.3.3 - 5.3.29
Warning: file_get_contents() expects parameter 1 to be string, resource given in /in/sn6ed on line 15 Warning: file_get_contents() expects parameter 1 to be string, resource given in /in/sn6ed on line 15
Output for 5.1.4 - 5.1.6, 5.2.0 - 5.2.13, 5.3.0 - 5.3.2
Strict Standards: Redefining already defined constructor for class Example in /in/sn6ed on line 13 Warning: file_get_contents() expects parameter 1 to be string, resource given in /in/sn6ed on line 15 Warning: file_get_contents() expects parameter 1 to be string, resource given in /in/sn6ed on line 15
Output for 5.0.2 - 5.0.5, 5.1.0 - 5.1.3
Strict Standards: Redefining already defined constructor for class Example in /in/sn6ed on line 13 Warning: fopen(php://memory): failed to open stream: Inappropriate ioctl for device in /in/sn6ed on line 9 Warning: fwrite(): supplied argument is not a valid stream resource in /in/sn6ed on line 10 Warning: fwrite(): supplied argument is not a valid stream resource in /in/sn6ed on line 20 Warning: fclose(): supplied argument is not a valid stream resource in /in/sn6ed on line 25
Output for 5.0.0 - 5.0.1
Strict Standards: Redefining already defined constructor for class Example in /in/sn6ed on line 13 Warning: fopen(php://memory): failed to open stream: Inappropriate ioctl for device in /in/sn6ed on line 9 Warning: fwrite(): supplied argument is not a valid stream resource in /in/sn6ed on line 10 Notice: Use of undefined constant PHP_EOL - assumed 'PHP_EOL' in /in/sn6ed on line 31 PHP_EOL Warning: fwrite(): supplied argument is not a valid stream resource in /in/sn6ed on line 20 Notice: Use of undefined constant PHP_EOL - assumed 'PHP_EOL' in /in/sn6ed on line 33 PHP_EOL Warning: fclose(): supplied argument is not a valid stream resource in /in/sn6ed on line 25
Output for 4.4.2 - 4.4.9
Parse error: syntax error, unexpected T_CLASS in /in/sn6ed on line 3
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1
Parse error: parse error, unexpected T_CLASS in /in/sn6ed on line 3
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error in /in/sn6ed on line 3
Process exited with code 255.

preferences:
247.33 ms | 401 KiB | 306 Q