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 instanceof stdClass) {} } $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){ $p = (($time1-$time2)/$time2) * 100; printf("'!== null' was faster by %.2f percent.", $p); } else { $p = (($time2-$time1)/$time1) * 100; printf("'instanceof' was faster by %.2f percent.", $p); }
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 = 34
Branch analysis from position: 34
2 jumps found. (Code = 44) Position 1 = 36, Position 2 = 31
Branch analysis from position: 36
2 jumps found. (Code = 43) Position 1 = 47, Position 2 = 56
Branch analysis from position: 47
1 jumps found. (Code = 42) Position 1 = 64
Branch analysis from position: 64
1 jumps found. (Code = 62) Position 1 = -2
Branch analysis from position: 56
1 jumps found. (Code = 62) Position 1 = -2
Branch analysis from position: 31
2 jumps found. (Code = 43) Position 1 = 33, Position 2 = 33
Branch analysis from position: 33
2 jumps found. (Code = 44) Position 1 = 36, Position 2 = 31
Branch analysis from position: 36
Branch analysis from position: 31
Branch analysis from position: 33
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/8VXcP
function name:  (null)
number of ops:  65
compiled vars:  !0 = $times, !1 = $var, !2 = $time1, !3 = $i, !4 = $time2, !5 = $p
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    3     0  E >   ASSIGN                                                   !0, 10000
    5     1        ASSIGN                                                   !1, null
    6     2        NEW                                              $8      'stdClass'
          3        DO_FCALL                                      0          
          4        ASSIGN                                                   !1, $8
    8     5        INIT_FCALL                                               'microtime'
          6        SEND_VAL                                                 <true>
          7        DO_ICALL                                         $11     
          8        ASSIGN                                                   !2, $11
   10     9        ASSIGN                                                   !3, 0
         10      > JMP                                                      ->14
   11    11    >   INSTANCEOF                                               !1, 'stdClass'
         12      > JMPZ                                                     ~14, ->13
   10    13    >   PRE_INC                                                  !3
         14    >   IS_SMALLER_OR_EQUAL                                      !3, !0
         15      > JMPNZ                                                    ~16, ->11
   14    16    >   INIT_FCALL                                               'microtime'
         17        SEND_VAL                                                 <true>
         18        DO_ICALL                                         $17     
         19        SUB                                              ~18     $17, !2
         20        ASSIGN                                                   !2, ~18
   16    21        ROPE_INIT                                     3  ~21     'Time+using+%27%21%27%3A+'
         22        ROPE_ADD                                      1  ~21     ~21, !2
         23        ROPE_END                                      2  ~20     ~21, '%0A'
         24        ECHO                                                     ~20
   19    25        INIT_FCALL                                               'microtime'
         26        SEND_VAL                                                 <true>
         27        DO_ICALL                                         $23     
         28        ASSIGN                                                   !4, $23
   21    29        ASSIGN                                                   !3, 0
         30      > JMP                                                      ->34
   22    31    >   TYPE_CHECK                                  1020          !1
         32      > JMPZ                                                     ~26, ->33
   21    33    >   PRE_INC                                                  !3
         34    >   IS_SMALLER_OR_EQUAL                                      !3, !0
         35      > JMPNZ                                                    ~28, ->31
   25    36    >   INIT_FCALL                                               'microtime'
         37        SEND_VAL                                                 <true>
         38        DO_ICALL                                         $29     
         39        SUB                                              ~30     $29, !4
         40        ASSIGN                                                   !4, ~30
   27    41        ROPE_INIT                                     3  ~33     'Time+using+%27%3D%3D%3D%27%3A+'
         42        ROPE_ADD                                      1  ~33     ~33, !4
         43        ROPE_END                                      2  ~32     ~33, '%0A'
         44        ECHO                                                     ~32
   29    45        IS_SMALLER                                               !4, !2
         46      > JMPZ                                                     ~35, ->56
   30    47    >   SUB                                              ~36     !2, !4
         48        DIV                                              ~37     ~36, !4
         49        MUL                                              ~38     ~37, 100
         50        ASSIGN                                                   !5, ~38
   31    51        INIT_FCALL                                               'printf'
         52        SEND_VAL                                                 '%27%21%3D%3D+null%27+was+faster+by+%25.2f+percent.'
         53        SEND_VAR                                                 !5
         54        DO_ICALL                                                 
         55      > JMP                                                      ->64
   33    56    >   SUB                                              ~41     !4, !2
         57        DIV                                              ~42     ~41, !2
         58        MUL                                              ~43     ~42, 100
         59        ASSIGN                                                   !5, ~43
   34    60        INIT_FCALL                                               'printf'
         61        SEND_VAL                                                 '%27instanceof%27+was+faster+by+%25.2f+percent.'
         62        SEND_VAR                                                 !5
         63        DO_ICALL                                                 
   35    64    > > RETURN                                                   1

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
144.26 ms | 1400 KiB | 17 Q