Así se puede ver como el sistema separa la memoria de código, la memoria de pila (stack) y la memoria del montón (heap).
Código
#include <stdio.h> #include <stdlib.h> char gc; int gi; int main(int argc, char *argv[]) { char c; int i; for(i = 0; i < argc; ++i) return 0; }
P. ej.:
$ ./c 1 12 123 1234 12345
printf = 0x4004f0
malloc = 0x400520
main = 0x40061d
gi = 0x60105c
gc = 0x601060
argv = 0x7ffd71212400
argc = 0x7ffd7121240c
c = 0x7ffd71212413
i = 0x7ffd71212414
p = 0x7ffd71212418
argv[0] = 0x7ffd71214551 -- ./c$
argv[1] = 0x7ffd71214555 -- 1$
argv[2] = 0x7ffd71214557 -- 12$
argv[3] = 0x7ffd7121455a -- 123$
argv[4] = 0x7ffd7121455e -- 1234$
argv[5] = 0x7ffd71214563 -- 12345$
p (->) = 0x1e36010