注意:这不是我应该“使用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; }
不优雅,但它应该工作.