标签:c containers iterator set
请考虑以下代码:
std::set<int> s;
auto it = s.begin();
s.insert(1);
s.insert(2);
std::cout << *it << std::endl;
输出(至少对我而言)是2.这里发生了什么?当我取消引用它时,它的状态是什么?
我知道当我在空集上调用begin()时,我得到一个等效于end()的迭代器.我也知道在集合上调用insert不会使其迭代器失效.即使我现在已经将元素插入集合中,迭代器也会以某种方式保持等效于end(),所以现在我得到了未定义的行为?这是由标准定义的吗?
解决方法:
当你在这里调用s.begin()时,它会返回一个结束迭代器,因为容器是空的.插入符号不会使此迭代器失效:每次插入后,此迭代器仍然是结束迭代器.
取消引用此迭代器会导致程序显示未定义的行为(无法取消引用结束迭代器).
标签:c,containers,iterator,set 来源: https://codeday.me/bug/20190725/1536679.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。