我想在此方法中为值分配一个向量 p->vertexlist 在某些迭代中,并且当 j= 3 和 i = 2 时一直存在内存问题(在迭代中)
void py_tetgenio::set_facets(bp::list python_facets) {
this->numberoffacets = bp::len(python_facets);
this->facetlist = new tetgenio::facet[this->numberoffacets];
this->facetmarkerlist = new int[this->numberoffacets];
for (int i = 0; i < this->numberoffacets; i++) {
//iterar por sobre la lista agregando cada uno de los
//identificadores a cada uno de los facets
bp::list facet = bp::extract<bp::list>(python_facets[i]);
tetgenio::facet *f = &this->facetlist[i];
f->numberofpolygons = 1;
f->polygonlist = new tetgenio::polygon[f->numberofpolygons];
f->numberofholes = 0;
f->holelist = NULL;
tetgenio::polygon *p = &f->polygonlist[i];
//iterar por sobre la lista de los id de los nodos
//almacenados en la lista que representa al facets
p->numberofvertices = bp::len(facet);
p->vertexlist = new int[p->numberofvertices];
for (int j = 0; j < p->numberofvertices; j++) {
int aux = bp::extract<int>(facet[j]);
p->vertexlist[j] = aux; // SIGSEV: Segmentation Fault!!! when j=3
// and i = 2
}
this->facetmarkerlist[i] = 1;
}
} //end set_facets
这是一个神秘的
注意:我们被告知i
是 2。
f->numberofpolygons = 1;
f->polygonlist = new tetgenio::polygon[f->numberofpolygons];
现在f->polygonlist
指向大小1
数组。
// Two irrelevant statements skipped
tetgenio::polygon *p = &f->polygonlist[i];
p
现在是f->polygonlist
中第三个(i == 2
)多边形的地址。哦,但是f->polygonlist
指向一个大小1
数组.