unordered_map.find() 匹配不同的键

unordered_map.find() matches on different keys

本文关键字:map find unordered      更新时间:2023-10-16

我正在学习C++。 我有这种方法,它在std::unordered_map中查找密钥,如果找到密钥,则返回 true,如果未找到,则返回 false。

bool BufferContainer::contains(std::string *file_path) {
EditorBuffer *buf = lookup_buffer(file_path);
if (buf != NULL)
return true;
return false;
}
EditorBuffer* BufferContainer::lookup_buffer(std::string *key) {            
auto buffer = buffer_map.find(key);
if (buffer == buffer_map.end())
return NULL;
return buffer->second;
}

我也有一点代码来测试这些方法。它添加一个缓冲区,然后查看其他字符串指针是否匹配。

TEST(BufferContainer, NotContainsBuffer) {
std::string name = "buffer";
std::string name2 = "buffer2";
BufferContainer container;
container.open_buffer(&name);
EXPECT_FALSE(container.contains(&name2));
} 

现在的问题是,这个测试失败了。如果我在堆上创建字符串,测试将按预期成功。

TEST(BufferContainer, NotContainsBuffer) {
std::string *name = new std::string("buffer");
std::string *name2 = new std::string("buffer2");
BufferContainer container;
container.open_buffer(name);
EXPECT_FALSE(container.contains(name2));
}

这个问题有什么解决方案吗,还是我做错了什么? 也许我应该将实际字符串存储为键,但在我看来,这会有很多开销。

编辑:我知道我比较了地址,但我无法在最小的工作示例中重现此问题。

这是完整的"程序"。 测试在test/testeditor/test_buffer_container.cpp. 容器的代码在libeditor/buffer_container.cpp中。 https://github.com/FlexW/tedit

BufferContainer

使用全局变量作为其映射,不与特定的BufferContainer实例相关联。一个测试插入的条目在另一个测试中可见。那张全球地图上塞满了悬空的指针。

碰巧的是,测试中的name2NotContainsBuffer与先前某些测试插入到映射中的字符串位于同一堆栈位置。