Understanding Stack, Heap and Memory Management
int *ip = new int[10];
for (int i = 0; i<10; i++)
*(ip+i) = i;
myfun(ip); // assume that myfun takes an argument of
// type int* and returns no result
delete [] ip;
The above code is a small segment of a test function that I am trying to use to learn about the stack and the heap.
I am not fully sure what the correct sequence is.
This is what I have thus far:
delete []ip;
removes the memory allocated on the heap to the ip pointer. The pointer that got passed through to myFun now points to nothing. Would someone be able to clarify if I am correct or not and correct me where I went wrong? Also if I attempted to carry on using ip after that would it just point to nothing ?
The sequence is correct except one point:
The delete []ip; removes the memory allocated on the heap to the ip pointer. The pointer that got passed through to myFun now points to nothing.
The pointer doesn't point to 'nothing' (ie isn't set to nullptr
or 0
after freeing the memory). It just points to the same location which is now freed memory (ie memory marked as freed by the application and that can no longer be safely accessed). Accessing memory through that pointer would trigger undefined behavior.
One last notice: myfun
might take the pointer by value or by reference. There are differences but your sentence would still be valid.
I believe everything is correct, I have the following minor remark regarding the following bullet point;
It is not guaranteed that the pointer points to "nothing", in general it is recommended (see clarification in comment below this answer) that after your delete
call, you initialize the pointer to NULL, ie ip = NULL
in order to ensure the pointer points to nothing (instead of pointing to unallocated memory).
Everything is correct. But beware that calling delete
doesn't delete anything but free the memory previously allocated, which means that your pointer contains the address that you mustn't use (dereferencing a free chunk of memory leeads to undefined behavior). The same for your stack variable, the memory associated to your local variable is not destroyed but released, so you mustn't try to use it. stack and heap are just two ways of memory management with two basic same operation (alloc/free).
So technically you can't say that your pointer points to anything, but it points to something that you are not authorized to use.
链接地址: http://www.djcxy.com/p/13870.html下一篇: 了解堆栈,堆和内存管理