Van-e sebességbeli különbség a be / be, míg az át, és miközben a beágyazott hurkok között a C / C ++?


Válasz 1:
int
fő (int argc, char * argv [])
{
   int i, g = 0xf;

   for (i = 0; i <16; i ++)
     g--;
}
int
fő (int argc, char * argv [])
{
   int i = 0, g = 0xf;

   csináld {
      g--;
      i ++;
   } míg (i <16);
}
int
fő (int argc, char * argv [])
{
   int i = 0, g = 0xf;

   míg (i <16) {
      g--;
      i ++;
   };
}
        .file "main_for.c"
        .szöveg
        .globl main
        .típus main, @function
fő:
.LFB0:
        .cfi_startproc
        pushq% rbp
        .cfi_def_cfa_offset 16
        .cfi_offset 6, -16
        movq% rsp,% rbp
        .cfi_def_cfa_register 6
        movl% edi, -20 (% rbp)
        movq% rsi, -32 (% rbp) <--- Mindez fent programinit
        movl $ 15, -8 (% rbp) <- g változónk
        movl $ 0, -4 (% rbp) <- Az i változó
        jmp .L2
.L3:
        subl $ 1, -8 (% rbp) <--- csökkentés g
        addl $ 1, -4 (% rbp) <--- növekedés i
.L2:
        cmpl 15 USD, -4 (% rbp) <--- hasonlítsuk össze a 15-rel
        jle .L3 <---- ugorjon a következő iterációra, ha kevesebb vagy egyenlő
        popq% rbp <----- Ez alatt minden a program tisztítása
        .cfi_def_cfa 7, 8
        áztat
        .cfi_endproc
.LFE0:
        .s main main,.-main
        .ident "GCC: (Gentoo 4.7.3-r1 p1.4, pie-0.5.5) 4.7.3"
        .sekció .note.GNU-stack, "", @ progbits
        movl $ 0, -4 (% rbp) <- Az i változó
        movl $ 15, -8 (% rbp) <- g változónk
        jmp .L2
.L3:
        subl $ 1, -8 (% rbp) <--- csökkentés g
        addl $ 1, -4 (% rbp) <--- növekedés i
.L2:
        cmpl 15 USD, -4 (% rbp) <--- hasonlítsuk össze a 15-rel
        jle .L3 <---- ugorjon a következő iterációra, ha kevesebb vagy egyenlő
        movl $ 0, -4 (% rbp)
        movl 15 USD, -8 (% rbp)
.L2:
        subl $ 1, -8 (% rbp)
        addl $ 1, -4 (% rbp)
        cmpl 15 USD, -4 (% rbp)
        jle .L2
       .file "main_for.c"
        .section .text.startup, "ax", @ progbits
        .p2align 4,, 15
        .globl main
        .típus main, @function
fő:
.LFB0:
        .cfi_startproc
        ismétlés
        áztat
        .cfi_endproc
.LFE0:
        .s main main,.-main
        .ident "GCC: (Gentoo 4.7.3-r1 p1.4, pie-0.5.5) 4.7.3"
        .sekció .note.GNU-stack, "", @ progbits
fő:
.LFB0:
        .cfi_startproc
        movl 15 USD, -4 (% rsp) <----- Számított i végfeltétel (cecI)
        movl $ 16,% eax <------- g változónk regisztrációban van
        .p2align 4,, 10
        .p2align 3
.L2:
        movl -4 (% rsp),% edx <---- vigye a cecI-t egy regiszterbe
        subl $ 1,% edx <--- csökkentés cecI
        subl $ 1,% eax <--- csökkentés g regisztráció szerint
        movl% edx, -4 (% rsp) <- regisztráció áthelyezése a cecI-be
        jne .L2
        ismétlés
        áztat
.LFB0:
        .cfi_startproc
        movl 15 USD, -4 (% rsp)
        movl $ 16,% eax
        .p2align 4,, 10
        .p2align 3
.L2:
        movl -4 (% rsp),% edx
        subl $ 1,% edx
        subl $ 1,% eax
        movl% edx, -4 (% rsp)
        jne .L2
int
fő (int argc, char * argv [])
{
   int x, y;
   illékony g = 0xf;

   mert (y = 0; y <16; y ++) {
      for (x = 0; x <10; x ++) {
         g--;
      }
   }
}
int
fő (int argc, char * argv [])
{
   int x, y = 0;
   illékony int g = 0xf;

   az (y = 0; y <16; y ++, X = 0) {
      míg (x ++ <10) {
         g--;
      }
   }
}
fő:
.LFB0:
        .cfi_startproc
        movl 15 USD, -4 (% rsp)
        movl 16 USD,% ecx
        .p2align 4,, 10
        .p2align 3
.L2:
        movl 10 USD,% eax
        .p2align 4,, 10
        .p2align 3
.L3:
        movl -4 (% rsp),% edx
        subl $ 1,% edx
        subl $ 1,% eax
        movl% edx, -4 (% rsp)
        jne .L3
        subl $ 1,% ecx
        jne .L2