3v4l.org

run code in 300+ PHP versions simultaneously
<?php declare(ticks=1); function tick_handler() { echo "tick_handler() called\n"; } function inverse($x) {tick_handler(); if (!$x) {tick_handler(); throw new Exception('Division by zero.'); tick_handler(); } return 1/$x; tick_handler(); } try { echo inverse(5) . "\n"; echo inverse('FALSE') . "\n"; } catch (Exception $e) { echo 'Caught exception: ', $e->getMessage(), "\n"; } ?>
Output for 8.0.0 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
tick_handler() called 0.2 tick_handler() called Fatal error: Uncaught TypeError: Unsupported operand types: int / string in /in/L6hui:14 Stack trace: #0 /in/L6hui(21): inverse('FALSE') #1 {main} thrown in /in/L6hui on line 14
Process exited with code 255.
Output for 7.1.0 - 7.1.25, 7.2.0 - 7.2.33, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33
tick_handler() called 0.2 tick_handler() called Warning: A non-numeric value encountered in /in/L6hui on line 14 Warning: Division by zero in /in/L6hui on line 14 INF
Output for 7.0.0 - 7.0.20
tick_handler() called 0.2 tick_handler() called Warning: Division by zero in /in/L6hui on line 14 INF
Output for 5.3.28 - 5.3.29, 5.4.20 - 5.4.45, 5.5.24 - 5.5.35, 5.6.8 - 5.6.28
tick_handler() called 0.2 tick_handler() called Warning: Division by zero in /in/L6hui on line 14
Output for 5.0.0 - 5.0.5, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.27, 5.4.0 - 5.4.19
tick_handler() called 0.2 tick_handler() called Warning: Division by zero in /in/91M0v on line 14
Output for 4.4.2 - 4.4.9
Parse error: syntax error, unexpected T_NEW in /in/91M0v on line 11
Process exited with code 255.
Output for 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1
Parse error: parse error, unexpected T_NEW in /in/91M0v on line 11
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error in /in/91M0v on line 11
Process exited with code 255.
Output for 4.3.0
Parse error: parse error, unexpected T_NEW in /in/L6hui on line 11
Process exited with code 255.

preferences:
217.53 ms | 401 KiB | 329 Q