为什么malloc 出来的对象也能正常使用
新学习C++语言的人会感觉到很疑惑,因为相比于C语言,C++多了个类;也正是这个类给很多人带来了困扰,class 究竟是什么,它和struct 的差别又是什么?
结构体我们能使用new申请,也能使用malloc申请使用都没有问题,但是在类的创建教科书中给的方法是使用new进行创建。为什么一定要使用new进行创建?
搜索new和malloc的区别我们可以看到如下说明:
- malloc与free是c++/c语言的标准函数,new/delete是C++的运算符。
- new返回指定类型的指针,并且可以自动计算出所需的大小
- new不仅会申请一块内存还会主动调用申请对象的构造函数,然后delete在清除对象的时候会主动的调用对象的析构函数。
其实new内部也是调用malloc实现的,只不过new更加智能,除了会自动计算出所需大小还会主动调用所申请对象构造函数。
那么我们要是想使用malloc申请类对象,只需要保证申请的内存够用,然后手动调用成员函数对需要初始化或者赋值的数据进行赋值即可:
using namespace std;
class Base {
public:
void SetData(int32_t data) {
m_data = data;
}
int32_t GetData() const {
return m_data;
}
private:
int32_t m_data{12};
};
Base* lpBase = static_cast<Base *>(malloc(sizeof(Base)));
lpBase->SetData(12);
cout << lpBase->GetData() << endl;
从输出结果可以看出,就算是malloc申请的内存,也能正常的按照类使用,需要注意的是malloc申请内存时没有调用构造函数
注意
博客发出后有人问我,为什么使用malloc申请的一块内存能够调用对象的成员函数,成员函数不应该是属于对象的吗?
这里说明一下,对象的实现是比C语言里面的类实现复杂了点,但是也没有想象中的那么复杂,所有类的成员函数也好,静态函数也好,都和是否创建对象无关,都只有一份。类的成员函数需要必须需要类对象调用的原因是因为,成员函数在调用的时候必须传入this指针,你通过lpData调用成员函数时,就是把lpData当成this指针传给SetData等成员函数了,因此malloc申请的“对象”也能正常调用类的成员函数。
|