为了在运行时动态分配内存,C在它的标准库函数中提供了一些函数:从堆中
申请内存的函数malloc()以及它的变种calloc()和realloc()、释放内存返回
给堆的函数free()
使用C的动态内存分配函数在堆上创建一个类
//: C13:MallocClass.cpp
// From Thinking in C++, 2nd Edition
// Available at http://www.BruceEckel.com
// (c) Bruce Eckel 2000
// Copyright notice in Copyright.txt
// Malloc with class objects
// What you'd have to do if not for "new"
#include "../require.h"
#include <cstdlib> // malloc() & free()
#include <cstring> // memset()
#include <iostream>
using namespace std;
class Obj {
int i, j, k;
enum { sz = 100 };
char buf[sz];
public:
void initialize() { // Can't use constructor
cout << "initializing Obj" << endl;
i = j = k = 0;
memset(buf, 0, sz);
}
void destroy() const { // Can't use destructor
cout << "destroying Obj" << endl;
}
};
int main() {
Obj* obj = (Obj*)malloc(sizeof(Obj));
require(obj != 0);
obj->initialize();
// ... sometime later:
obj->destroy();
free(obj);
getchar();
} ///:~
用户必须决定对象的长度
由于malloc()只是分配了一块内存而不是生成一个对象,所以它返回了一个
void*类型指针
malloc()可能找不到可分配的内存,所以必须检查返回的指针以确保内存
分配成功
用户在使用对象之前必须记住对它初始化。注意构造函数没有被使用,因为
构造函数不能被显式地调用--它是在对象创建时由编译器调用
许多程序设计者发现C的动态内存分配函数太复杂,容易令人混淆
输出
initializing Obj
destroying Obj