实例化结构-C 时分割故障



我有一个问题,试图从波前文件加载3D对象并将其保存到我预定的结构中。我遇到了一个细分故障错误,我假设我的指针在某个地方出错了。以下是:

struct vertex
{
    float x,y,z;
};
// the idea is to split each object into groups in order to animate
// them seperately
struct group
{
    float xpos, ypos, zpos;
    float xrot, yrot, zrot;
    int numVertices;
    int numFaces;
    //all verteces
    vertex vertices[MAX_NUM];
    //faces-- a face is made up of one vertex from each of these arrays
    vertex vertexOne[MAX_NUM];
    vertex vertexTwo[MAX_NUM];
    vertex vertexThree[MAX_NUM];
};
struct object
{
    float xpos, ypos, zpos;
    float xrot, yrot, zrot;
    int numGroups;
    group * groups[MAX_NUM];
};

这是应该加载对象的功能:

object * loadObject(char * path)
{
object * obj;
obj = new object;
char str[1];
obj->numGroups = 0;
FILE * file = fopen(path, "r");
while(fscanf(file, "%s", str) != EOF)
{
    if(str[0] == 'o')
    {
        obj->numGroups++;
        obj->groups[obj->numGroups-1] = new group;
        obj->groups[obj->numGroups-1]->numVertices = 0;
        obj->groups[obj->numGroups-1]->numFaces = 0;
    }
    else if(str[0] == 'v' && str[1] == ' ')
    {
        obj->groups[obj->numGroups-1]->numVertices++;
        sscanf(str, "v %f %f %f",
        &(obj->groups[obj->numGroups-1]->vertices[obj->groups[obj->numGroups-1]->numVertices-1].x),
        &(obj->groups[obj->numGroups-1]->vertices[obj->groups[obj->numGroups-1]->numVertices-1].y),
        &(obj->groups[obj->numGroups-1]->vertices[obj->groups[obj->numGroups-1]->numVertices-1].z));
    }
    else if(str[0] == 'f')
    {
        int one, two, three;
        obj->groups[obj->numGroups-1]->numFaces++;
        sscanf(str, "f %i/%*i/%*i %i/%*i/%*i %i/%*i/%*i", &one, &two, &three);
        obj->groups[obj->numGroups-1]->vertexOne[obj->groups[obj->numGroups-1]->numFaces-1] = obj->groups[obj->numGroups-1]->vertices[one-1];
        obj->groups[obj->numGroups-1]->vertexTwo[obj->groups[obj->numGroups-1]->numFaces-1] = obj->groups[obj->numGroups-1]->vertices[two-1];
        obj->groups[obj->numGroups-1]->vertexThree[obj->groups[obj->numGroups-1]->numFaces-1] = obj->groups[obj->numGroups-1]->vertices[three-1];
    }
}
fclose(file);
return obj;
}

我已经尝试了很长时间来找到问题,但是我根本没有有关错误的信息。我知道我分配顶点和面孔的方式有些乏味,任何关于整洁代码的建议都非常欢迎。请告诉我是否需要任何其他信息,非常感谢您。

首先您要做

obj->numGroups = 0;

然后在某些情况下

obj->groups[obj->numGroups-1]

没有增加 obj->numGroups的情况,这意味着您可以访问数组之路。您也不会检查阵列条目是否已分配。


另一个问题是str只是一个字符,您的fscanf扫描字符串,该字符串至少将两个字符放入字符串中:您想要的实际字符,然后字符串终结者字符。您还将在循环中访问str[1],该循环不超出范围。所有这些都是不确定的行为,可能导致崩溃。

如果我是您,我会远离各种fscanf()sscanf()等。处理输入的功能。他们可以使用dice。请参阅此FSCANF MAN页面,因为我认为您正在假设FSCANF()的完整字符串,并且您可能不会得到它。

我要采用的方法将是以下步骤:(1)使用fgets()和(2)使用递归下降解析器(另请参见有关递归血统解析的另一篇文章)在文件中读取完整的字符串,以解析字符串我走时构建对象。

相关内容

  • 没有找到相关文章

最新更新