作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在遍历集合时遇到段错误。堆栈跟踪指向
std::_Rb_tree_const_iterator<Type>::operator++
std::_Rb_tree_increment()
但我没有得到更多信息。迭代器在函数返回的集合上
for (FactSet::factset_iterator fact_it = (*binSet_it).getDependencyGraph().getExtentionalFactSet().begin();
fact_it != (*binSet_it).getDependencyGraph().getExtentionalFactSet().end();
++fact_it) {...}
我看不到这个问题。提前致谢。
最佳答案
您不希望像那样迭代返回值。每次迭代都会重新评估中间终止条件,因此您的 end()
每次都针对不同的集合,这意味着您的迭代器永远不会到达它。
将集合缓存在局部变量中,然后使用其中的 begin()
和 end()
。
关于c++ - 来自 std::_Rb_tree_const_iterator<Type>::operator++ 的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2355454/
我在遍历集合时遇到段错误。堆栈跟踪指向 std::_Rb_tree_const_iterator::operator++ std::_Rb_tree_increment() 但我没有得到更多信息。迭代
这个问题在这里已经有了答案: Error: "no match for operator+" , for list iterator (4 个答案) 关闭 6 年前。 我有一个名为 assets 的
对 std::set 的所有元素执行 xor 时出现一些错误。下面是部分代码。不太了解 std::transform。请帮忙 :) #include #define ll long l
我是一名优秀的程序员,十分优秀!