Sarebbe questo essere considerato una perdita di memoria?
-
04-10-2019 - |
Domanda
Si consideri questo programma inutile:
/* main.c */
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char **argv) {
int i;
for (i = 0; i < 1024; i++) {
int pid = fork();
int status;
if (pid) {
wait(&status);
}
else {
char *ptr = (char *)malloc(1024*sizeof(char));
char *args[2] = {"Hello, world!", NULL};
execve("/bin/echo", args, NULL);
}
}
}
Non sarebbe liberando ptr
costituiscono una perdita di memoria sia per main.ce o l'altro programma, o è in corso di essere liberato in ogni caso quando execve si chiama?
Soluzione
No.
Non si tratta di una perdita di memoria. exec*()
farà una copia locale dei dati stringa nella matrice args, poi soffiare via l'immagine della memoria processo figlio e sovrapporre è l'immagine della memoria utilizzata da /bin/echo
con. Essenzialmente tutto che rimane dopo l'exec () è il pid.
Modifica:
User318904 portato il caso di exec () restituisce -1 (cioè guasto). In questo caso, il processo figlio che ha biforcuta, ma non è riuscito a exec fa, infatti tecnicamente hanno una perdita di memoria, ma come al solito risposta ad un'exec riuscito è quello di uscire da solo il processo figlio in ogni modo, la memoria verrà recuperato dal sistema operativo. Eppure, liberandolo è probabilmente una buona abitudine per entrare, se non altro perché da quello che vi terrà da chiedersi a questo proposito in seguito.
Altri suggerimenti
Quando ritorna execve -1, sì. In caso contrario, forse.
La memoria allocata deve essere liberata exec
. Dopo la chiamata viene completata non è possibile accedere in ogni caso.