3v4l.org

run code in 300+ PHP versions simultaneously
<?php $times = 10000; $var = null; $var = new stdClass(); $time1 = microtime(true); for ($i = 0; $i <= $times; $i++) { if (!$var) {} } $time1 = microtime(true) - $time1; //echo "Time using '!': $time1\n"; $time2 = microtime(true); for ($i = 0; $i <= $times; $i++) { if ($var === null) {} } $time2 = microtime(true) - $time2; //echo "Time using '===': $time2\n"; if ($time1 > $time2) echo "'===' was faster by {($time1-$time2)/$time2}%"; else echo "'!' was faster by {($time2-$time1)/$time1}%";
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 42) Position 1 = 14
Branch analysis from position: 14
2 jumps found. (Code = 44) Position 1 = 16, Position 2 = 11
Branch analysis from position: 16
1 jumps found. (Code = 42) Position 1 = 30
Branch analysis from position: 30
2 jumps found. (Code = 44) Position 1 = 32, Position 2 = 27
Branch analysis from position: 32
2 jumps found. (Code = 43) Position 1 = 39, Position 2 = 48
Branch analysis from position: 39
1 jumps found. (Code = 42) Position 1 = 56
Branch analysis from position: 56
1 jumps found. (Code = 62) Position 1 = -2
Branch analysis from position: 48
1 jumps found. (Code = 62) Position 1 = -2
Branch analysis from position: 27
2 jumps found. (Code = 43) Position 1 = 29, Position 2 = 29
Branch analysis from position: 29
2 jumps found. (Code = 44) Position 1 = 32, Position 2 = 27
Branch analysis from position: 32
Branch analysis from position: 27
Branch analysis from position: 29
Branch analysis from position: 11
2 jumps found. (Code = 43) Position 1 = 13, Position 2 = 13
Branch analysis from position: 13
2 jumps found. (Code = 44) Position 1 = 16, Position 2 = 11
Branch analysis from position: 16
Branch analysis from position: 11
Branch analysis from position: 13
filename:       /in/VRTT3
function name:  (null)
number of ops:  57
compiled vars:  !0 = $times, !1 = $var, !2 = $time1, !3 = $i, !4 = $time2
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    3     0  E >   ASSIGN                                                   !0, 10000
    5     1        ASSIGN                                                   !1, null
    6     2        NEW                                              $7      'stdClass'
          3        DO_FCALL                                      0          
          4        ASSIGN                                                   !1, $7
    8     5        INIT_FCALL                                               'microtime'
          6        SEND_VAL                                                 <true>
          7        DO_ICALL                                         $10     
          8        ASSIGN                                                   !2, $10
   10     9        ASSIGN                                                   !3, 0
         10      > JMP                                                      ->14
   11    11    >   BOOL_NOT                                         ~13     !1
         12      > JMPZ                                                     ~13, ->13
   10    13    >   PRE_INC                                                  !3
         14    >   IS_SMALLER_OR_EQUAL                                      !3, !0
         15      > JMPNZ                                                    ~15, ->11
   14    16    >   INIT_FCALL                                               'microtime'
         17        SEND_VAL                                                 <true>
         18        DO_ICALL                                         $16     
         19        SUB                                              ~17     $16, !2
         20        ASSIGN                                                   !2, ~17
   19    21        INIT_FCALL                                               'microtime'
         22        SEND_VAL                                                 <true>
         23        DO_ICALL                                         $19     
         24        ASSIGN                                                   !4, $19
   21    25        ASSIGN                                                   !3, 0
         26      > JMP                                                      ->30
   22    27    >   TYPE_CHECK                                    2          !1
         28      > JMPZ                                                     ~22, ->29
   21    29    >   PRE_INC                                                  !3
         30    >   IS_SMALLER_OR_EQUAL                                      !3, !0
         31      > JMPNZ                                                    ~24, ->27
   25    32    >   INIT_FCALL                                               'microtime'
         33        SEND_VAL                                                 <true>
         34        DO_ICALL                                         $25     
         35        SUB                                              ~26     $25, !4
         36        ASSIGN                                                   !4, ~26
   29    37        IS_SMALLER                                               !4, !2
         38      > JMPZ                                                     ~28, ->48
   30    39    >   ROPE_INIT                                     7  ~30     '%27%3D%3D%3D%27+was+faster+by+%7B%28'
         40        ROPE_ADD                                      1  ~30     ~30, !2
         41        ROPE_ADD                                      2  ~30     ~30, '-'
         42        ROPE_ADD                                      3  ~30     ~30, !4
         43        ROPE_ADD                                      4  ~30     ~30, '%29%2F'
         44        ROPE_ADD                                      5  ~30     ~30, !4
         45        ROPE_END                                      6  ~29     ~30, '%7D%25'
         46        ECHO                                                     ~29
         47      > JMP                                                      ->56
   32    48    >   ROPE_INIT                                     7  ~35     '%27%21%27+was+faster+by+%7B%28'
         49        ROPE_ADD                                      1  ~35     ~35, !4
         50        ROPE_ADD                                      2  ~35     ~35, '-'
         51        ROPE_ADD                                      3  ~35     ~35, !2
         52        ROPE_ADD                                      4  ~35     ~35, '%29%2F'
         53        ROPE_ADD                                      5  ~35     ~35, !2
         54        ROPE_END                                      6  ~34     ~35, '%7D%25'
         55        ECHO                                                     ~34
         56    > > RETURN                                                   1

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
151.4 ms | 1400 KiB | 15 Q