当deRERECHENCER结果访问std :: find_if时,内存访问不良
Bad memory access when dereferencing results of std::find_if
bool hasId(string id, vector<User>& map)
{
User ans = *(find_if(map.begin(), map.end(), [&](User d)
{ return (id==(d).uid());}));
return ans.uid() == id;
}
如果找不到匹配,则find_if
返回last()
,在您的情况下,map.end()
。end()
不会返回有效的迭代器(它是最后一个元素),但是您假设始终找到匹配项并继续取消返回值。这是个问题。
您需要在退出之前进行检查。没有检查您的功能,您的功能只是假定始终发现匹配为ans.uid() == id
是 find_if
的谓词(因此冗余),因此您不妨将整个物品替换为return true;
,因为它是:)
bool hasId(string id, vector<User>& map)
{
return map.end() != find_if(map.begin(), map.end(), [&](User d)
{
return id == d.uid();
});
}
在旁注上,称为vector
A map
有点奇怪,至少令人困惑。
find_if
的文档相关位:
template< class InputIt, class UnaryPredicate >
InputIt find_if( InputIt first, InputIt last, UnaryPredicate p );
返回值
迭代器到满足条件的第一个元素,或者如果找不到这样的元素。
您的实现可能就是这样:
bool hasId(string id, vector<User>& map)
{
return map.end() !=
find_if(map.begin(), map.end(), [&](User d){ return d.uid()==id; });
}
但是,由于您无论如何都使用C 11,因此您可以使用任何_of。
return any_of(map.begin(), map.end(), [&](User d){ return d.uid()==id; });
相关文章:
- 通过方法访问结构
- 使用不带参数的函数访问结构元素
- 如果我只是不访问queue_front节点的子节点,而是将它们推到队列中呢?还是BFS吗
- 用于访问容器<T>数据成员的正确 API
- 访问者访问变体并返回不同类型时出错
- 尝试通过多个向量访问变量时,向量下标超出范围
- 无法访问嵌套类.类的使用无效
- 写入位置0x0000000C时发生访问冲突
- 我们可以访问一个不存在的联盟的成员吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 我的简单if-else语句是如何无法访问的代码
- 从C++dll访问C#中的一行主要参数
- 概念TS检查忽略私有访问修饰符
- 访问被拒绝后,c++中的故障保护代码
- 从触摸回调访问向量元素的方法时,不良访问错误
- C - 空数对象的初始化发送不良访问错误
- 不良访问C 错误
- 当deRERECHENCER结果访问std :: find_if时,内存访问不良
- 安装可可荚后,现有的静态库不使用libssl.A表示TLS连接和访问不良
- C&Lua防止不良访问或双重释放