将数组信息存储到 c++ 向量中有一个"Access violation reading location"

Storing array information into c++ vector has an "Access violation reading location"

本文关键字:有一个 Access violation location reading 向量 信息 数组 存储 c++      更新时间:2023-10-16

当我尝试将顶点和三角形面信息加载到向量中时,我得到"访问冲突读取位置"。

这是我的加载代码:

struct TriangleData {
PointEntry  *ptidx[3];
bool    deleted;
};
class PointEntry {
public:
float   x, y, z;
std::vector<TriangleData*>  trianglelist;
friend bool operator < (const PointEntry&a, const PointEntry&b) { return (a.x < b.x) || ((a.x == b.x) && (a.y < b.y)) || ((a.x == b.x) && (a.y == b.y) && (a.z < b.z)); };
friend bool operator == (const PointEntry&a, const PointEntry&b) { return !(a<b) && !(b<a); }
friend bool operator != (const PointEntry&a, const PointEntry&b) { return !(a == b); }
};
for (int i = 0; i < num_triangles; i++) {
PointEntry tmp;
PointEntry *p;
for (int j = 0; j<3; j++) {
tmp.x = verts[3 * indicies[3 * i + j] + 0];
tmp.y = verts[3 * indicies[3 * i + j] + 1];
tmp.z = verts[3 * indicies[3 * i + j] + 2];
auto found = find(points.begin(), points.end(), tmp);
if (found == points.end()) {
points.push_back(tmp);
p = (PointEntry *)&(*(find(points.begin(), points.end(), tmp)));
}
else {
p = (PointEntry *)&(*found);
}
if (p->trianglelist.capacity() < 20) {
p->trianglelist.reserve(20);
}
triangle.ptidx[j] = p; 
}
triangle.deleted = false;
tlist.push_front(triangle);
std::list<TriangleData>::iterator tri = tlist.begin();
TriangleData* t = &*tri;
PointEntry *pt = t->ptidx[0];
pt->trianglelist.push_back(t); ***// fails here!***
pt = t->ptidx[1];
pt->trianglelist.push_back(t);
pt = t->ptidx[2];
pt->trianglelist.push_back(t);
}

代码总是在我尝试push_back我的三角数据*时中断。 我尝试单步执行每一行代码,但我还没有弄清楚为什么会发生这种情况。

有趣的是,当我使用Set数据结构而不是Vector时,代码工作正常,它按预期输出原始模型。

关于我为什么访问无效位置的任何建议都会有所帮助,谢谢!

有趣的是,当我使用 Set 数据结构而不是 向量,代码工作正常,它将原始模型输出为 预期。

这是您问题的解决方案,使用 set 而不是向量。

如果points是 Vector,则无法存储指向 Vector 项的指针,因为在调用时push_backVector 项被重新分配,并且指向它们的指针无效。

打电话给push_back

points.push_back(tmp);

所有以前的作业都p喜欢

p = (PointEntry *)&(*found);

可能引用无效指针。

您的程序崩溃,因为您想要访问无效指针的成员trianglelist

pt->trianglelist.push_back(t); ***// fails here!***
相关文章: