正确写法一:sz1指向的是堆空间,由程序员自己动态分配、释放内存new[] delete[]
char* sz1 = new char[5];
if(sz1!= NULL)
delete[] sz1;
正确写法二:sz2指向的是堆空间,由程序员自己动态分配、释放内存 new delete
char* sz2 = new char;
if(sz2!= NULL)
delete sz2;
return 0;
错误写法:sz指向的是栈空间,程序执行完了,会自动清除,此处不需要delete
char* sz = “my test”;
if(sz != NULL)
delete sz;
堆、栈区别总结:
1.堆栈空间分配
①栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
②堆(操作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。
2.堆栈缓存方式
①栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放。
②堆则是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定(并不是一旦成为孤儿对象就能被回收)。所以调用这些对象的速度要相对来得低一些。
3.堆栈数据结构区别
①堆(数据结构):堆可以被看成是一棵树,如:堆排序。
②栈(数据结构):一种先进后出的数据结构。