Why doesn't deleting my pointer delete my pointer?

前端 未结 8 1614
悲哀的现实
悲哀的现实 2021-02-13 04:22

So to understand new/delete better (really to prove to myself with small examples why virtual destructors are needed for interfaces), I want to understand memory leaks, so that

相关标签:
8条回答
  • 2021-02-13 04:56

    This would be a memory leak:

    int* P1 = new int(43);
         P1 = new int(42);
    

    Allocating memory without deleting it again.

    0 讨论(0)
  • 2021-02-13 04:57

    I must be doing something very simple very wrong.

    You're absolutely right. Your code is doing something very simple very wrong, and you've paid the ultimate price - not seeing any negative results. Sometimes, you do things wrong, and nothing bad happens. This is the worst possible outcome, because you may not realize your code is wrong, and you'll continue to use it, until one day your code breaks unexpectedly, and you'll have no idea where or how because it's always worked before. It'll break somewhere completely irrelevant to the actual part that's wrong, and you'll spend hours trying to track it down and figure out why it's broken.

    When you do things wrong, it's undefined behavior. That means anything can happen. At best, your code crashes and segfaults and blinking lights come on saying "YOU'RE USING FREED MEMORY" and everything is very clear. At worst, demons fly out of your nose. But just above that, the second worst possible outcome is that everything appears to work as you intended it to.

    0 讨论(0)
  • 2021-02-13 05:05

    You are causing undefined behaviour. This means that anything can happen. Since something did indeed happen, everything behaves as documented. (Sometimes "something" looks very similar to something else that you might erroneously expect. Doing exactly what you think you were trying to achieve is one of the possible allowed instances of "undefined behaviour".)

    Note also that a "memory leak" is sort of the opposite of what you're trying to do - in a memory leak you forget to free memory, whereas you already freed the memory and are now accessing invalid memory.

    Here's a real memory leak, which also does not cause undefined behaviour -- don't confuse "bad but correct" with "incorrect" programming!

    int * factorial(int * n)
    {
      if (*n == 0) return new int(1);
      else return new int(*n * *factorial(*n - 1));
    }
    
    0 讨论(0)
  • 2021-02-13 05:05

    This code

    delete P1;
    
    cout<<"P1 = "<<P1<<endl;
    cout<<"*P1 = "<<*P1<<endl;
    

    causes undefined-behavior. So anything can happen. It's much easier to cause a memory leak:

    for(;;) new int;
    
    0 讨论(0)
  • 2021-02-13 05:13

    Dereferencing a deleted pointer is undefined behavior, as already explained, i.e. you are doing something wrong. Compilers may help you find that error by changing the pointer's value to some magic value that will always cause dereferencing the pointer to fail and can give you a clue that it's because it was previously deleted.

    A quick test showed the following behavior for me:
    MSVC2010:
    debug build: *P1 = 0xfeeefeee
    release build: *P1 = <random>
    GCC 4.6:
    debug & release builds: *P1 = 0

    So you were just (un)lucky that you got again the original value. I recommend you to always build in debug mode for testing your programs (even if you aren't debugging) because it adds additional sanity checks to your code.

    0 讨论(0)
  • 2021-02-13 05:18

    Delete doesn't invalidate the pointer. It releases the memory it points to back to the heap. In this case, the memory hasn't been reused and therefore still contains the same content. At some point that memory WILL be reused and then you get the undefined behavior that others speak of.

    This isn't a memory leak though. That's when you point the pointer to another memory allocation (or just discard the pointer) without freeing the memory it points to. The first then stays allocated and, as you've no references to it, you've no way of freeing it.

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