Si su única intención es incrementar el valor de num entonces el primero y el segundo método rendirá mismo resultado intented a el método callee.
Sin embargo, si cambia su código a la siguiente, se puede ver la diferencia entre el código generado por gcc (código de nivel de ensamblado):
struct my_struct
{
int num;
};
void foo(struct my_struct* my_ptr)
{
printf("\nPost Increment: %d", my_ptr->num++);
}
int main()
{
struct my_struct a;
a.num = 10;
foo(&a);
}
Ahora compilarlo usando: -masm gcc = Intel - S structTest.c -o structTest.s Esto le pide a gcc que genere el código de ensamblado:
Abra structTest.s en un editor de texto.
foo:
.LFB0:
push rbp
mov rbp, rsp
sub rsp, 16
**mov QWORD PTR [rbp-8], rdi**
mov rax, QWORD PTR [rbp-8]
mov eax, DWORD PTR [rax]
mov edx, eax
**lea ecx, [rax+1]**
mov rax, QWORD PTR [rbp-8]
mov DWORD PTR [rax], ecx
mov eax, OFFSET FLAT:.LC0
mov esi, edx
mov rdi, rax
mov eax, 0
call printf
leave
ret
.cfi_endproc
main:
.LFB1:
push rbp
mov rbp, rsp
sub rsp, 16
**mov DWORD PTR [rbp-16], 10
lea rax, [rbp-16]
mov rdi, rax
call foo**
leave
ret
.cfi_endproc
Y cuando cambie la operación de pre-incremento, se genera el código follwoing:
foo:
.LFB0:
.cfi_startproc
push rbp
mov rbp, rsp
sub rsp, 16
**mov QWORD PTR [rbp-8], rdi**
mov rax, QWORD PTR [rbp-8]
mov eax, DWORD PTR [rax]
**lea edx, [rax+1]**
mov rax, QWORD PTR [rbp-8]
**mov DWORD PTR [rax], edx**
mov rax, QWORD PTR [rbp-8]
**mov edx, DWORD PTR [rax]**
mov eax, OFFSET FLAT:.LC0
mov esi, edx
mov rdi, rax
mov eax, 0
call printf
leave
ret
.cfi_endproc
Por lo tanto, se podría ver que en el segundo caso, el compilador incrementa el valor num y pases en este valor num para printf().
En términos de rendimiento, espero que el incremento posterior sea más eficiente ya que las ubicaciones de memoria se tocan menos veces.
Las líneas importantes se han marcado entre ** en el código anterior.