does exit() free allocated memory on both _SUCCESS and _FAILURE

前端 未结 4 2494
旧时难觅i
旧时难觅i 2021-02-19 16:43

This a short snippet of code, with two calls to exit(3) in case of failure. Do these calls deallocate memory allocated by malloc? Google search once says it does, a

相关标签:
4条回答
  • 2021-02-19 17:16

    When you exit the program, all allocated memory is reclaimed by the OS (both the stack and the heap). Your program doesn't leave any footprint in the RAM, unless you work outside the program's memory through buffer overflows and such.

    0 讨论(0)
  • 2021-02-19 17:22

    Yes, all memory is returned. BTW, what would you want to do with leftover memory after the exit anyway?
    Or are you worrying about a memory leak in exit()? If the memory weren't reclaimed, it would leak a bit more with each exiting process, which is something no credible OS could afford. So, except for a buggy OS, stop worrying about memory and use exit() wherever you need it.

    To answer the questions in the comments of your code, whether to free, I'd say it's proper software engineering to write a corresponding free with every malloc. If that appears hard, it is pointing to a structural problem in your code. The benefit of freeing all memory before exiting is that you can use powerful tools like valgrind to check for memory leaks in the rest of your code without false positives from the malloc you've shown us.

    Note that after a failed malloc there is no point in attempting to free the result--it's a null pointer anyway.

    And third, I prefer if (pointer == NULL) over if (!pointer) but this is totally subjective and I can read and understand both :-)

    0 讨论(0)
  • 2021-02-19 17:26

    After calling exit you're beyond malloc and friends but the OS reclaims everything. Think of malloc as a convenient intermediary between the OS and your process.

    0 讨论(0)
  • 2021-02-19 17:27

    Just a note that at those 2 calls to exit you have - you have failed to allocate any memory, so freeing that pointer is going to be pretty pointless (and might crash, depending on how old your C runtime system is).

    So, no, you shouldn't free it, because it doesn't exist.

    I'd have said in the case of a fatal error like that, you probably don't want to bother freeing up memory.

    However, if your program exits normally, yes, you should try and free up all the memory you have allocated. That can be quite tricky sometimes.

    0 讨论(0)
提交回复
热议问题