C++ Memory Leak Using STL Containers

前端 未结 3 2054
天命终不由人
天命终不由人 2020-12-12 04:55

The following code is giving me a memory leak (using Visual Studio):

#define _CRTDBG_MAP_ALLOC
#include 
#include 
#include &         


        
相关标签:
3条回答
  • 2020-12-12 05:22

    std::vector<Listener*> listeners; will not free the members of Listeners. You'd have to delete each of the listeners that are inside the vector, using something like:

    for (int i = 0; i < listeners.size(); i++) delete listeners[i]
    

    Personally, I avoid such issues by using smart pointers:

    std::vector<std::unique_ptr<Listener>> listeners
    

    _CrtDumpMemoryLeaks detects leaks by counting news and making sure they all match. Because subject never goes out of scope, I'm guessing it is counted as an outstanding reference. Try int main(void) {{Subject subject;}_CrtDumpMemoryLeaks(); return 1}

    0 讨论(0)
  • 2020-12-12 05:24

    Make sure that the Listener destructor destroys everything it needs to. All the STL container does is invoke the destructor of the object it is holding. It is still your responsibility to handle memory in the class itself.

    To be more specific, anything declared with a new or malloc in the class must be freed by the destructor. The STL container won't know how to delete that.

    0 讨论(0)
  • 2020-12-12 05:25

    The vector is destroyed when the program exits, you don't need to ensure it. You do need to ensure that _CrtDumpMemoryLeaks is called after that destruction if you don't want it to report the allocated memory as "leaked":

    int main()
    {
        { Subject subject; }
        _CrtDumpMemoryLeaks();
        return 1;
    }
    
    0 讨论(0)
提交回复
热议问题