#include <iostream>
#include <string>
#include <cstdio>
using namespace std;
typedef struct node{
string str;
}NODE;
int main(){
string var = "lirao";
NODE * node = (NODE *)malloc (sizeof(NODE));
node->str = var;
}
对于这个程序,在程序调试过程中,在程序的最后一行是无论如何都过不了的。出现的错误就是内存访问冲突。但是如果我们把malloc分配的内存改为new分配,NODE*node = new NODE(),问题立马就解决了,这是为什么呢?
只是因为在NODE 结构中包含了string类型成员,用malloc分配时,由于malloc没有这样的机制,导致无法调用string的构造函数,所以无法构建起string对象,给一个不存在的对象赋值肯定错误。但是new分配内存时有这样的机制,调用了string的构造函数,所以就构建起了对象,内存访问冲突就不会发生了。
本文探讨了使用C++编程语言时,malloc与new在结构体包含string类型成员时的不同行为及原因。通过具体实例说明了为何malloc会导致内存访问冲突,而new则可以正确构建对象。
6万+

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



