栈(stack),先进后出,位于一级缓存中,操作系统自动分配释放 ,存放函数的参数值,局部变量的值等,被调用时处于存储空间中,调用完毕立即释放。
堆(heap),堆包含一个链表来维护已用和空闲的不连续的内存块,存放在二级缓存中,一般由程序员分配释放。
快速记忆方式:
一级缓存比二级缓存快,栈是一个先进后出列表,存取非常快,所以栈是在一级缓存中。
栈中不能随机取数据,只能取最上面的一个,存放的内容必然要有严格的存取顺序,所以适合函数调用时的形参、局部变量。
栈空间有限,一般PC一级缓存就几M,所以其中的数据也是快速使用,快速删除。像形参、局部变量,在函数调用结束系统就会把数据主动销毁了。
堆空间大,由程序员维护,系统不会主动销毁。
示例代码(参考自:http://blog.csdn.net/cscmaker/article/details/7019977):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | #include <iostream> using namespace std; class TestNew { private: int ID; public: TestNew(int ID); ~TestNew(); }; TestNew::TestNew(int ID) { this->ID = ID; } TestNew::~TestNew() { std::cout<<"对象 "<<this->ID<<" 执行析构函数"<<std::endl; } void Test() { TestNew test(1);//创建对象1,不使用new,存储在栈中 TestNew *pTest = new TestNew(2);//创建对象2,使用new,存储在堆中 //delete pTest; } int main() { Test();//这个地方有点问题,pTest没有进行处理,会导致内存泄露,实际应用中要注意呀 } |
输出结果:
对象 1 执行析构函数
说明函数调用结束,对象1被系统主动销毁了。
如果把Test()方法中,delete前的注释去掉。输出:
对象 2 执行析构函数
对象 1 执行析构函数