我正在尝试将程序从Java移植到C,我似乎无法弄清楚如何将LinkedHashMap转换为std :: map . 我无法更改LinkedHashMap,但我不限于std :: map . 我需要它来生成相同的键/值对,但订购/散列/其他任何不重要的事情 .
要转换的Java代码:
List faces = new ArrayList(modelFull.faces.length);
Map map = new LinkedHashMap();
for (int i = 0; i < modelFull.faces.length; i++) {
Face f = new Face(modelFull.faces[i]);
faces.add(f);
for (int k = 0; k < 3; k++) {
Point3D p = f.pts[k];
Integer v = map.get(p);
if (v == null) {
v = 0;
}
map.put(p, v + 1);
}
}
我的尝试:
std::map pointMap;
auto modelFaces = modelFull.getFaces();
for (const auto &face : modelFaces)
{
Face newFace = Face(face);
for (int k = 0; k < 3; ++k)
{
RVPoint3D pt = newFace.getPts()[k];
++pointMap[pt];
}
faces.push_back(newFace);
}
Java实现创建了一个大小为7523的映射,C one为7967.两者共检查了45234个元素,因此它似乎正在通过潜在的密钥正确迭代 .
我不知道从哪里开始 . 我已经尝试过载运算符,自定义比较器,自定义哈希函数等,我必须遗漏一些东西 .