C++学习笔记3
2013-02-28 14:58
162 查看
3.new 和 delete ~~~malloc 和 free
malloc 和 free 会产生问题的原因在于它们太简单:他们不知道构造函数和析构函数。
string * stringarray_f=static_cast<string*>(malloc(10 * sizeof(string)));
string * stringarray_s= new string[10];
其结果是,stringarray_f确实指向的是可以容纳10个string对象的足够空间,但内存里并没有创建这些对象。你没有办法来初始化数组里的对象。换句话说,stringarray_f其实一点用也没有。相反,stringarray_s指向的是一个包含10个完全构造好的string对象的数组,每个对象可以在任何读取string的操作里安全使用。
既然new和delete可以这么有效地与构造函数和析构函数交互,选用它们是显然的。
把new和delete与malloc和free混在一起用也是个坏想法。对一个用new获取来的指针调用free,或者对一个用malloc获取来的指针调用delete,其后果是不可预测的。
new/delete和malloc/free的不兼容性常常会导致一些严重的复杂性问题。既然malloc和free对构造函数和析构函数一无所知,把malloc/free和new/delete混起来用又象嘈杂拥挤的晚会那样难以控制,那么,你最好就什么时候都一心一意地使用new和delete吧。
malloc 和 free 会产生问题的原因在于它们太简单:他们不知道构造函数和析构函数。
string * stringarray_f=static_cast<string*>(malloc(10 * sizeof(string)));
string * stringarray_s= new string[10];
其结果是,stringarray_f确实指向的是可以容纳10个string对象的足够空间,但内存里并没有创建这些对象。你没有办法来初始化数组里的对象。换句话说,stringarray_f其实一点用也没有。相反,stringarray_s指向的是一个包含10个完全构造好的string对象的数组,每个对象可以在任何读取string的操作里安全使用。
free(stringarray_f); delete [] stringarray_s;//
调用free将会释放stringarray_f指向的内存,但内存里的string对象不会调用析构函数。如果string对象象一般情况那样,自己已经分配了内存,那这些内存将会全部丢失。相反,当对stringarray_s调用delete时,数组里的每个对象都会在内存释放前调用析构函数。
既然new和delete可以这么有效地与构造函数和析构函数交互,选用它们是显然的。
把new和delete与malloc和free混在一起用也是个坏想法。对一个用new获取来的指针调用free,或者对一个用malloc获取来的指针调用delete,其后果是不可预测的。
new/delete和malloc/free的不兼容性常常会导致一些严重的复杂性问题。既然malloc和free对构造函数和析构函数一无所知,把malloc/free和new/delete混起来用又象嘈杂拥挤的晚会那样难以控制,那么,你最好就什么时候都一心一意地使用new和delete吧。
相关文章推荐
- C++ primer第二次阅读学习笔记(第5章)
- C/C++学习笔记-标准库类型
- C++学习笔记--数组操作符重载
- c++内存管理学习笔记结束语
- 【C++】【学习笔记】/*函数声明的四种方式*/
- 一个C++程序员的Delphi学习笔记
- 【C++】学习笔记草稿版系列1(C到C++类型安全增强)
- C/C++学习笔记(五)面向对象的编程
- C++学习笔记:16章 泛型编程
- C++内存管理学习笔记(5)
- C++学习笔记(八):对字符的操作函数和范围for语句的使用
- C++学习笔记六之函数如何使用指针来处理数组?
- C++学习笔记--从虚函数说开去
- C++ 播放声音 (学习笔记)
- c++学习笔记--异常处理
- C++学习笔记2:数组与容器,指针与迭代器
- C++学习笔记(八)----表(list)的实现
- C++ Primer Plus学习笔记之拷贝构造函数
- 设计模式C++学习笔记之四(Multition多例模式)
- C++中继承方式与访问标号的学习笔记