如何分辨 boost::split_iterator 从字符串中间开始
How to tell boost::split_iterator to start in the middle of string?
我想遍历字符串中的标记:
#include <boost/algorithm/string.hpp>
using namespace boost::algorithm;
typedef split_iterator<std::string::const_iterator> SplitIter;
for(SplitIter i = make_split_iterator(str, token_finder(is_space()));
i != SplitIter(); ++i)
std::cout << *i << std::endl; // prints token
这种使用 split_iterator
的方法对我来说是理想的,因为它不会将匹配项复制到向量中,而只是迭代它找到的范围,因此非常有效。
现在,我如何修改它,以便拆分迭代器在 str[5]
开始搜索,例如,而不是在字符串的开头?当然,因为我想避免不必要的复制,所以我不想在子字符串副本str.substr(5)
上进行搜索。
你可以自己构建迭代器:
for(SplitIter i = split_iterator<std::string::const_iterator>(
str.begin() + 5,
str.end(),
token_finder(is_space()));
i != SplitIter(); ++i)
std::cout << *i << 'n'; // prints token