C++微专业课程辅导(内存模型和动态内存)
2015-09-15 11:03
441 查看
“除了静态内存和栈内存之外,每个程序还拥有一个内存池。这部分空间被称作自由空间(free store)或堆(heap)。程序用堆来存储动态分配(dynamically allocate)的对象”——《C++ primer(第五版)》 P400
栈
*由系统自动管理,以执行函数为单位。
*空间大小编译时确定(参数 + 局部变量)。
*函数执行时,系统自动分配一个stack。
*函数执行结束,系统立即自动回收stack。
*具有局部性,大小有限额,超出会stack overflow。
与上图对应的代码应该为
堆
*分配由程序员手动请求new。
*释放由程序员手动释放delete,如果忘记则会内存泄漏。
*具有全局性,总体大小没有限制(受制于系统内存整体大小)。
与上图对应的代码
栈
*由系统自动管理,以执行函数为单位。
*空间大小编译时确定(参数 + 局部变量)。
*函数执行时,系统自动分配一个stack。
*函数执行结束,系统立即自动回收stack。
*具有局部性,大小有限额,超出会stack overflow。
与上图对应的代码应该为
class Point { int x; int y; } void foo() { Point sp; sp.x = 10; sp.y = 20; }
堆
*分配由程序员手动请求new。
*释放由程序员手动释放delete,如果忘记则会内存泄漏。
*具有全局性,总体大小没有限制(受制于系统内存整体大小)。
与上图对应的代码
class Point { int x; int y; } void foo() { Point *pt = new Point(); pt->x = 10; pt->y = 20; delete pt; }
相关文章推荐
- 【C++】二叉树的创建方法及其遍历的递归与非递归方法总结
- 【第3周 项目2 - 建设“顺序表”算法库】
- C++Primer第五版 6.5.1节练习
- C++Primer第五版 6.4节练习
- C++模板
- C++Primer第五版 6.3.3节练习
- C++外观设计模式模式(三)
- c++中的数据类型
- 线性表的C++实现
- C++Primer第五版 6.3.2节练习
- c++容器类
- C++中pair用法
- c++生成伪随机数的方法
- C++Primer第五版 6.2.6节练习
- C++Primer第五版 6.2.5节练习
- 绝对不要重新定义继承而来的non-virtual函数(Effective C++_36)
- C++Primer第五版 6.2.4节练习
- 浅谈 C++ 中的 new/delete 和 new[]/delete[]
- C++Primer第五版 6.2.3节练习
- OpenCV/source/sample/cpp的学习