如何正确地将boost::asio::buffers_iterator转换为InputIterator

How to properly cast boost::asio::buffers_iterator as InputIterator

本文关键字:iterator 转换 InputIterator buffers asio 正确地 boost      更新时间:2023-10-16

我在std::string构造函数:中使用boost::asio::buffers_iterator

std::unique_ptr<boost::asio::streambuf> receiveBuf;
size_t length = <>; // calculate length
...
std::string message(boost::asio::buffers_begin(receiveBuf->data()),
boost::asio::buffers_begin(receiveBuf->data()) + length);

代码工作正常,但隐蔽性抱怨:

(1) Event no_matching_constructor:  no instance of constructor "std::__cxx11::basic_string<_CharT, _Traits, _Alloc>::basic_string [with _CharT=char, _Traits=std::char_traits<char>, _Alloc=std::allocator<char>]" matches the argument list
(2) Event caretline:    ^
(3) Event argument_list_types_add_on:   argument types are: (boost::asio::buffers_iterator<boost::asio::const_buffers_1, char>, <error-type>)

所以,我想知道,如何正确地转换boost的迭代器?

更新在@Caleth指出+length后,结果并不那么明显。我必须承认,我过于简化了我的示例代码(为了专注于最相关的部分(,所以,我用了一种错误的方式。很抱歉造成混淆,但对于上面显示的例子,隐蔽性是无声的。当谜题中还有一块时,它会抱怨:

std::unique_ptr<boost::asio::streambuf> receiveBuf;
size_t length = <>; // calculate length
size_t delimSize = <>; // delimiter size
...
std::string message(boost::asio::buffers_begin(receiveBuf->data()),
boost::asio::buffers_begin(receiveBuf->data()) + length - delimSize);

所以,看起来迭代器可以是高级的(运算符+重载?(,但不能被减去(好吧,代码编译并工作,但至少对覆盖性来说是不好的(。。。

错误来自无效的表达式boost::asio::buffers_begin(receiveBuf->data()) + length

如果length的意思是"缓冲区中的所有数据",则需要boost::asio::buffers_end(receiveBuf->data())

std::string message(boost::asio::buffers_begin(receiveBuf->data()),
boost::asio::buffers_end(receiveBuf->data()));

否则,您将需要用类似std::copy_n的东西填充message

std::string message(length);
std::copy_n(boost::asio::buffers_begin(receiveBuf->data()), length, message.begin());

具有+RandomAccessIterator的一个特性,这是一个比InputIterator更严格的约束