动态分配内存的原理
来源:互联网 发布:蓝牙共享网络给电脑 编辑:程序博客网 时间:2024/06/09 13:06
FAQ 2.07
C++允许用new指针动态分配内存,动态分配也就是从堆分配。下面显示了用语法new Car()从堆分配Car对象。结果被存在一个CarPtr指针中,CarPtr是一个auto_ptr的别名,这是一种"安全指针类型"。typedef语法建立了相对应的别名。
#include <memory> <-- 1#include <string>using namespace std;#include "Car.hpp"typedef auto_ptr<Car> CarPtr;void f(){ CarPtr p(new Car()); <-- 1 p->startEngine(); <-- 2 p->tuneRadioTo("AM", 770); <-- 3} <-- 4int main(){ f();}
(1) auto_ptr定义所在的头文件
(1)1.创建一个对象。
(2)2.调用一个成员函数
(3)3.调用另外一个成员函数
(4)4.销毁Car对象。
当控制流经过行标签1.创建一个对象,一个对象被动态创建(从堆),指针P指向了对象。从对象CarPtr被创建到对象CarPtr在}(第4行)被销毁之前对象可以一直被访问。注意CarPtr能被返回到调用者。这一行类似于(但是不能互相代替)C代码P = malloc(sizeof(Car)).注意参数能被传递到构造器中,例如P = new Car(100, 73);
当控制流经过行标签2:调用一个成员函数,startEngine()成员函数被对象指针P调用。行标签3:调用另一个成员函数,展示如何给动态分配的对象传递参数。
当控制流经过行标签4.销毁Car对象, P指向的Car对象被销毁,如果Car类有一个析构器,控制流经过这一行的时候运行时系统调用析构器。
注意动态分配对象不必在创建对象的区域中销毁。例如,函数中的return p;,Car对象的所有权被返回给调用者,它的意思是
Car对象直到到达调用者的}才被销毁(或者调用者的调用者...):
CarPtr g()
{
CarPtr p(new Car());
// ...
return p; <-- 1
}
void h()
{
CarPtr p = g(); <-- 2
// ...
} <-- 3
(1) 调用者负责删除Car对象。
(2) 所有者从g()转移到了h()
(3)Car对象在这而销毁
C程序员要注意:
用未处理过的Car *指针控制new Car()操作通常被认为是不好的形式。这种方式相对于传统的C语言中指针来说是一种巨大的变化。
C++方法使"内存泄漏"更少(没有显示的free(p)或者delete p,所以程序员不用担心忘记释放内存),
C++使"悬空引用" (dangling references)更少(如果C-Like Car * 指针被使用,就可能访问被删除的Car 对象)‘
C++方法使代码更容易"安全除错"(exception safe)(如果一个C-like Car *被使用,任何抛出异常的程序都必须使用try...catch包装块)。
此文章来自于【http://blog.csdn.net/jia_xiaoxin/article/details/2899267】
- 动态分配内存的原理
- 动态分配内存的原理
- 内存动态分配函数malloc的基本实现原理
- 内存的动态分配
- 关于内存的动态分配
- 内存的动态分配
- 简单的动态分配内存
- 建立内存的动态分配
- 请教高手,汇编动态分配内存原理
- C语言的动态分配内存
- 递归、内存的动态分配、指针
- 用户申请内存的动态分配
- 关于动态分配内存的问题
- CUDA 共享内存的动态分配
- 使用动态分配内存的理由
- 动态分配内存的指针问题
- 简单的动态分配内存2
- 简单的动态分配内存3
- QRCode 扫描二维码、扫描条形码、相册获取图片后识别、生成带 Logo 二维码、支持微博微信 QQ 二维码扫描样式
- Android应用开发中,给我们提供了4种数据的存储方式
- Linux 系统挂载数据盘
- Linux任务前后台的切换 【转】
- javascript闭包
- 动态分配内存的原理
- 开篇
- CodeForces - 687A (连通图染色)
- 磁盘I/O
- append("A").append("B").append("C")和append("ABC")
- linux目录结构
- 用Awstats工具来分析httpd和tomcat的访问日志
- Spring Ioc 源码的初探
- 微积分公理化,赶超美日不难