作者WGL (飞扬寒星)
看板NTUEE113HW
标题[问题] Dynamic Memory Allocation
时间Tue Jan 12 10:28:02 2010
※ [本文转录自 C_and_CPP 看板]
作者: WGL (飞扬寒星) 看板: C_and_CPP
标题: [问题] Dynamic Memory Allocation
时间: Tue Jan 12 10:25:32 2010
关於 delete [] 的问题,曾有同学提出:如果指针不再指向原来的位置,那麽
delete[]会有何效果?
於是,我设计了下面的code:
#include <iostream>
using namespace std;
class Count
{
public:
Count(int=0);
~Count();
int x;
};
Count::Count(int value) : x(value)
{
}
Count::~Count()
{
cout<<"\nDestructor for Count "<<x<<endl;
}
int main(){
Count *cptr = new Count [20];
for(int i=0;i<20;i++)
cptr[i].x=i;
cptr+=
11;
cout<<"\nNow cptr is at Count "<<cptr->x<<endl;
delete [] cptr;
system("pause");
return 0;
}
注意指针是指向第11个element。执行结果:
Now cptr is at Count 11
Destructor for Count
1330118735
Destructor for Count 19
Destructor for Count 18
Destructor for Count 17
Destructor for Count 16
Destructor for Count 15
Destructor for Count 14
Destructor for Count 13
Destructor for Count 12
Destructor for Count 11
可是如果把11改成1,结果如下:
Now cptr is at Count 1
这样就结束了!
请问,究竟delete[] call destrucor 的范围和pointer指向的位置到底有什麽关系呢?
谢谢!!
--
1F:→ tomap41017:以解决的解法是??? 01/12 13:15
2F:→ tomap41017:刚compile的结果跟你差不多 01/12 13:15
3F:→ tomap41017:推测delete []的方式是删掉array的元素个 01/12 13:16
4F:推 tomap41017:看到C++板上的回答了,感谢!! 01/12 13:22
5F:推 fu3mo6:它的compile结果是结束了吗?应该是卡住吧?执行完不会错误? 01/12 13:56
6F:→ WGL:不会错误 01/12 13:57
7F:→ WGL:我试过如果cptr--才会错误 01/12 13:58
8F:→ fu3mo6:我记得用阵列写法写的是const pointer,这样+-虽然不会错误 01/12 13:58
9F:→ fu3mo6:但是删除的时候会错 01/12 13:58
10F:→ fu3mo6:啊啊我说的不是不能compile,是指无法执行到底 01/12 13:59
11F:→ WGL:要看用哪一种compiler,会不会错要看运气XD 01/12 14:01
12F:→ WGL:cptr--compile也会过但是会错误因为这样读到的element数很奇怪 01/12 14:02
13F:推 fu3mo6:运气..我用VC++的,试了好多数字,似乎是+几就会有几-1次 01/12 14:07
※ 编辑: WGL 来自: 140.112.241.120 (01/12 14:09)
14F:→ fu3mo6:的destructor,而删掉的是几号却很谜 01/12 14:07