3v4l.org

run code in 300+ PHP versions simultaneously
<?php date_default_timezone_set('Europe/Prague'); $time = microtime(true); $micro_time = sprintf("%06d", ($time - floor($time)) * 1000000); $date = new DateTime(date('Y-m-d H:i:s.' . $micro_time, $time)); echo $date->format("Y-m-d H:i:s.u") . " - OK\n"; setlocale(LC_NUMERIC, 'cs_CZ.utf8'); $date = new DateTime(date('Y-m-d H:i:s.' . $micro_time, $time)); echo $date->format("Y-m-d H:i:s.u") . " - BAD!\n";
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/OkRs5
function name:  (null)
number of ops:  50
compiled vars:  !0 = $time, !1 = $micro_time, !2 = $date
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    3     0  E >   INIT_FCALL                                               'date_default_timezone_set'
          1        SEND_VAL                                                 'Europe%2FPrague'
          2        DO_ICALL                                                 
    5     3        INIT_FCALL                                               'microtime'
          4        SEND_VAL                                                 <true>
          5        DO_ICALL                                         $4      
          6        ASSIGN                                                   !0, $4
    6     7        INIT_FCALL                                               'sprintf'
          8        SEND_VAL                                                 '%2506d'
          9        INIT_FCALL                                               'floor'
         10        SEND_VAR                                                 !0
         11        DO_ICALL                                         $6      
         12        SUB                                              ~7      !0, $6
         13        MUL                                              ~8      ~7, 1000000
         14        SEND_VAL                                                 ~8
         15        DO_ICALL                                         $9      
         16        ASSIGN                                                   !1, $9
    8    17        NEW                                              $11     'DateTime'
         18        INIT_FCALL                                               'date'
         19        CONCAT                                           ~12     'Y-m-d+H%3Ai%3As.', !1
         20        SEND_VAL                                                 ~12
         21        SEND_VAR                                                 !0
         22        DO_ICALL                                         $13     
         23        SEND_VAR_NO_REF_EX                                       $13
         24        DO_FCALL                                      0          
         25        ASSIGN                                                   !2, $11
    9    26        INIT_METHOD_CALL                                         !2, 'format'
         27        SEND_VAL_EX                                              'Y-m-d+H%3Ai%3As.u'
         28        DO_FCALL                                      0  $16     
         29        CONCAT                                           ~17     $16, '+-+OK%0A'
         30        ECHO                                                     ~17
   11    31        INIT_FCALL                                               'setlocale'
         32        SEND_VAL                                                 1
         33        SEND_VAL                                                 'cs_CZ.utf8'
         34        DO_ICALL                                                 
   13    35        NEW                                              $19     'DateTime'
         36        INIT_FCALL                                               'date'
         37        CONCAT                                           ~20     'Y-m-d+H%3Ai%3As.', !1
         38        SEND_VAL                                                 ~20
         39        SEND_VAR                                                 !0
         40        DO_ICALL                                         $21     
         41        SEND_VAR_NO_REF_EX                                       $21
         42        DO_FCALL                                      0          
         43        ASSIGN                                                   !2, $19
   14    44        INIT_METHOD_CALL                                         !2, 'format'
         45        SEND_VAL_EX                                              'Y-m-d+H%3Ai%3As.u'
         46        DO_FCALL                                      0  $24     
         47        CONCAT                                           ~25     $24, '+-+BAD%21%0A'
         48        ECHO                                                     ~25
         49      > RETURN                                                   1

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
147.42 ms | 1405 KiB | 25 Q