3v4l.org

run code in 150+ php & hhvm versions
Bugs & Features
<?php class A { public function __construct() { throw new Exception("test"); } } class B extends A { public function __construct() { var_dump($this); try { parent::__construct(); } catch (Exception $e) { var_dump($e); var_dump($this); } } } $b = new B;
Output for 5.3.0 - 7.1.0
object(B)#1 (0) { } object(Exception)#2 (7) { ["message":protected]=> string(4) "test" ["string":"Exception":private]=> string(0) "" ["code":protected]=> int(0) ["file":protected]=> string(9) "/in/BaENl" ["line":protected]=> int(4) ["trace":"Exception":private]=> array(2) { [0]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(13) ["function"]=> string(11) "__construct" ["class"]=> string(1) "A" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [1]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(21) ["function"]=> string(11) "__construct" ["class"]=> string(1) "B" ["type"]=> string(2) "->" ["args"]=> array(0) { } } } ["previous":"Exception":private]=> NULL } object(B)#1 (0) { }
Output for 5.0.5 - 5.2.17
object(B)#1 (0) { } object(Exception)#2 (6) { ["message:protected"]=> string(4) "test" ["string:private"]=> string(0) "" ["code:protected"]=> int(0) ["file:protected"]=> string(9) "/in/BaENl" ["line:protected"]=> int(4) ["trace:private"]=> array(2) { [0]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(13) ["function"]=> string(11) "__construct" ["class"]=> string(1) "A" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [1]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(21) ["function"]=> string(11) "__construct" ["class"]=> string(1) "B" ["type"]=> string(2) "->" ["args"]=> array(0) { } } } } object(B)#1 (0) { }
Output for 5.0.3 - 5.0.4
object(B)#1 (0) { } object(Exception)#2 (6) { ["message:protected"]=> string(4) "test" ["string:private"]=> string(0) "" ["code:protected"]=> int(0) ["file:protected"]=> string(9) "/in/BaENl" ["line:protected"]=> int(4) ["trace:private"]=> array(3) { [0]=> array(5) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(4) ["function"]=> string(11) "__construct" ["class"]=> string(1) "A" ["type"]=> string(2) "::" } [1]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(13) ["function"]=> string(11) "__construct" ["class"]=> string(1) "B" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [2]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(21) ["function"]=> string(11) "__construct" ["class"]=> string(1) "B" ["type"]=> string(2) "->" ["args"]=> array(0) { } } } } object(B)#1 (0) { }
Output for 5.0.0 - 5.0.2
object(B)#1 (0) { } object(Exception)#2 (6) { ["message:protected"]=> string(4) "test" ["string:private"]=> string(0) "" ["code:protected"]=> int(0) ["file:protected"]=> string(9) "/in/BaENl" ["line:protected"]=> int(4) ["trace:private"]=> array(2) { [0]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(13) ["function"]=> string(11) "__construct" ["class"]=> string(1) "B" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [1]=> array(6) { ["file"]=> string(9) "/in/BaENl" ["line"]=> int(21) ["function"]=> string(11) "__construct" ["class"]=> string(1) "B" ["type"]=> string(2) "->" ["args"]=> array(0) { } } } } object(B)#1 (0) { }
Output for 4.4.2 - 4.4.9
Parse error: syntax error, unexpected T_STRING, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/BaENl on line 3
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.4.1
Parse error: parse error, unexpected T_STRING, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/BaENl on line 3
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error, expecting `T_OLD_FUNCTION' or `T_FUNCTION' or `T_VAR' or `'}'' in /in/BaENl on line 3
Process exited with code 255.