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?

È stato utile?

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.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top