微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c – 通过插入保持std :: list迭代器有效

注意:这不是我应该“使用list还是deque”的问题.这是一个关于insert()面对迭代器有效性的问题.

这可能是一个简单的问题,我只是太密集了,看不到正确的方法来做到这一点.我正在实现(无论好坏)网络流量缓冲区作为std :: list< char> buf,我将当前的读取位置保持为迭代器readpos.

当我添加数据时,我会做类似的事情

buf.insert(buf.end(),newdata.begin(),newdata.end());

我现在的问题是,如何保持readpos迭代器有效?如果它指向旧buf的中间,那么它应该没问题(通过std :: list的迭代器保证),但通常我可能已经读取并处理了所有数据,并且我有readpos == buf.end().在插入之后,我希望readpos总是指向下一个未读的字符,在插入的情况下应该是第一个插入的字符.

有什么建议? (没有将缓冲区更改为std :: deque< char>,这似乎更适合任务,如下所示.)

更新:从使用GCC4.4的快速测试中我发现deque和list在readpos = buf.end()方面表现不同:在最后插入后,readpos在列表中被破坏,但指向下一个元素双端队列.这是标准保证吗?

(根据cplusplus,任何deque :: insert()都会使所有迭代器失效.这没有用.也许使用计数器比迭代器更好地跟踪双端队列中的位置?)

解决方法

if (readpos == buf.begin())
{
    buf.insert(buf.end(),newdata.end());
    readpos = buf.begin();
}
else
{
    --readpos;
    buf.insert(buf.end(),newdata.end());
    ++readpos;
}

不优雅,但它应该工作.

原文地址:https://www.jb51.cc/c/239528.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐