delete p后,只是释放了指针指向的内存空间。p并不会自动被置为NULL,而且指针还在,同时还指向了之前的地址
delete NULL编译器不会报错(因为delete空指针是合法的)
例:
对一个非空指针delete后,若没有赋NULL,若再次delete的话,有可能出现问题。
如下代码
1 int *p = new int(3);
2 delete p;
3 delete p;
用VC编译运行将出现问题。
将其改为:
1 int *p = new int(3);
2 delete p;
3 p = NULL;
4 delete p;
则不会出现问题(因为delete空指针是合法的)