1. new申请时会执行构造函数,而malloc仅仅申请空间不执行任何操作
先测试如下带参数的构造函数:
class Test
{
public:
Test(int num) : _num(num)
{
std::cout << "Created Test with " << _num << endl;
}
private:
int _num;
};
可以看到其构造函数带一个参数,并且在前导中执行私有变量_num的初始化操作,函数体中打印提示信息。下面时主函数。
int main()
{
Test * pt1 = new Test(10);
}
程序运行结果如下。
Created Test with 10
请按任意键继续. . .
可以看出其执行了构造函数及前导。下面用malloc进行测试。
int main()
{
Test * pt2 = (Test *)malloc(sizeof(Test));
}
程序运行结果:
请按任意键继续. . .
没有任何提示信息输出,说明构造函数并没有被执行。
综上,在C++中就尽量不要用malloc了,之所以说在c++中也常使用malloc,那是在一些特定情况下。
2. 在不需要构造函数做太复杂操作或者对一些结构体活内置类型变量申请空间时仍然可以使用malloc,不过记得使用memset函数进行初始化。
比如下面这个类。
class Test
{
public:
Test()
{
std::cout << "Created Test" << std::endl;
}
private:
int _num;
};
由于并未在构造函数里做任何实际操作(除了打印点提示信息),所以如下两种方式皆可行。
int main()
{
Test * pt1 = new Test;
Test * pt2 = (Test *)malloc(sizeof(Test));
}
当然唯一区别就是前者打印了提示信息。
动态分配的空间来自堆,指针指向堆空间的一个地址,而指针本身作为局部变量在栈里。
本文探讨了C++中new与malloc的区别,指出new在申请内存时会执行构造函数,而malloc仅分配空间。在不涉及复杂构造函数操作或处理结构体和内置类型时,可以考虑使用malloc并配合memset初始化。建议在C++编程中尽量避免使用malloc。
1665

被折叠的 条评论
为什么被折叠?



