我在下面有一个C ++代码,它创建了一个指向struct
的指针数组#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#define WATCH(x) std::cout << #x << ": " << x << std::endl;
typedef struct
{
double thickness;
char name[80];
virtual double getDensity() const {return 0.1;}
} mat_prop_t;
struct mat_el_prop : public mat_prop_t
{
double density;
double young;
double poisson;
virtual double getDensity() const {return density;}
};
int main(int argc, char** argv)
{
mat_prop_t** mat_prop;
mat_prop = (mat_prop_t**) calloc(1, sizeof(mat_prop_t*));
mat_prop[0] = (mat_prop_t*) calloc(1, sizeof(mat_el_prop));
mat_el_prop* mat1 = (mat_el_prop*) mat_prop[0];
mat1->density = 2.038735;
mat1->young = 2.0;
mat1->poisson = 0.3;
mat1->thickness = 1.0;
WATCH(mat1->density)
WATCH(mat1->getDensity())
free(mat_prop[0]);
free(mat_prop);
return 0;
}
我认为构造是正确的,但它在行
处给出了一个seg错误错误WATCH(mat1->getDensity())
但是,删除virtual
关键字后,代码运行正常。有人可以帮我解释一下原因吗?
答案 0 :(得分:2)
calloc()
只能用于为原始类型和POD结构分配空间。由于您的struct具有虚函数,因此它不是POD,因此您需要使用new
来确保正确创建vtable。
mat_prop_t **mat_prop = new mat_prop_t*[1];
mat_prop[0] = new mat_el_prop;
mat_el_prop *mat1 = mat_prop[0];
您可以在技术上将calloc()
用于mat_prop
,因为它是一个指针数组。但是在C ++中,你通常应该使用new
,而不是C内存分配函数。