调用struct的虚函数时出现seg错误

时间:2016-08-12 20:46:53

标签: c++ struct segmentation-fault

我在下面有一个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关键字后,代码运行正常。有人可以帮我解释一下原因吗?

1 个答案:

答案 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内存分配函数。