C++编程思想 第1卷 第13章 动态对象创建 重新设计前面的例子 使用delete void*可能会出错

如果想对一个void*类型指针进行delete操作,要注意这可能成为一个程序错误,
除非所指的内容是非常简单的,因为,它将不执行析构函数

 

//: C13:BadVoidPointerDeletion.cpp
// From Thinking in C++, 2nd Edition
// Available at http://www.BruceEckel.com
// (c) Bruce Eckel 2000
// Copyright notice in Copyright.txt
// Deleting void pointers can cause memory leaks
#include <iostream>
using namespace std;

class Object {
  void* data; // Some storage
  const int size;
  const char id;
public:
  Object(int sz, char c) : size(sz), id(c) {
    data = new char[size];
    cout << "Constructing object " << id 
         << ", size = " << size << endl;
  }
  ~Object() { 
    cout << "Destructing object " << id << endl;
    delete []data; // OK, just releases storage,
    // no destructor calls are necessary
  }
};

int main() {
  Object* a = new Object(40, 'a');
  delete a;
  void* b = new Object(40, 'b');
  delete b;
  getchar();
} ///:~


类Object包含了一个void*指针,它被初始化指向“元”数据 它没有指向含有
析构函数的对象

在main()中,我们看到使delete知道它所操作的对象的类型是十分有必要的

因为delete a知道a指向一个Object对象,使用析构函数将会被调用,从而
释放了分配给data的内存

如果在程序中发现内存丢失的情况,那么就搜索所有的delete

输出
Constructing object a, size = 40
Destructing object a
Constructing object b, size = 40

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值