如果行尾表示为\r\n
(例如在 Windows 机器上),您将拥有您提到的行为。getline用作\n
默认分隔符。
#include <iostream>
#include <vector>
#include <sstream>
#include <boost/tokenizer.hpp>
int main() {
std::string line;;
std::istringstream iss("(1,2)\r\n");
std::getline(iss, line);
std::cout << "length: " << line.length() << std::endl; // 6, includes '\r'
boost::char_separator<char> sep("(),");
typedef boost::tokenizer<boost::char_separator<char> > tokenizer;
tokenizer tok(line, sep);
for (auto &i : tok) {
std::cout << "ith tok: " << i << std::endl;
}
return 0;
}
印刷:
length: 6
ith tok: 1
ith tok: 2
ith tok:
要解决此问题,您可以更改分隔符或编写从流中解析坐标的方法,如下所示:
#include <iostream>
#include <algorithm>
#include <vector>
#include <sstream>
#include <iterator>
template <typename CharT, typename CharTraits, typename T>
std::basic_istream<CharT, CharTraits>& operator >>(std::basic_istream<CharT, CharTraits>& is, std::vector<T>& v)
{
typedef typename std::vector<T> vector_type;
typedef typename vector_type::size_type size_type;
CharT ch;
const size_type size = 2;
vector_type s{0,0};
if(is >> ch && ch != '(')
{
is.putback(ch);
is.setstate(std::ios_base::failbit);
}
else if(!is.fail())
{
for(size_type i = 0; i != size; ++i)
{
if(is >> std::ws >> s[i] >> ch && ch != ',')
{
is.putback(ch);
if(i < size - 1)
is.setstate(std::ios_base::failbit);
break;
}
}
if(is >> ch && ch != ')')
{
is.putback(ch);
is.setstate(std::ios_base::failbit);
}
}
if(!is.fail())
v.swap(s);
return is;
}
int main() {
std::vector<int> v;
std::istringstream is("(1, 2)\r\n");
is >> v;
std::copy(std::begin(v), std::end(v), std::ostream_iterator<int>(std::cout, " "));
std::cout << std::endl;
return 0;
}
印刷
1 2
在线运行