我正在尝试将整个流(多行)读成字符串。
我正在使用这段代码,但它确实有效,但它冒犯了我的风格......当然有一种更简单的方法吗?也许使用stringstreams?
void Obj::loadFromStream(std::istream & stream)
{
std::string s;
std::streampos p = stream.tellg(); // remember where we are
stream.seekg(0, std::ios_base::end); // go to the end
std::streamoff sz = stream.tellg() - p; // work out the size
stream.seekg(p); // restore the position
s.resize(sz); // resize the string
stream.read(&s[0], sz); // and finally, read in the data.
<小时/> 实际上,
const
对字符串的引用也可以,这可能会使事情变得更容易......
const std::string &s(... a miracle occurs here...)
答案 0 :(得分:103)
怎么样
std::istreambuf_iterator<char> eos;
std::string s(std::istreambuf_iterator<char>(stream), eos);
(如果不是MVP,可能是单线)
2011年后编辑,这种方法现在拼写
std::string s(std::istreambuf_iterator<char>(stream), {});
答案 1 :(得分:23)
我迟到了,但这是一个相当有效的解决方案:
std::string gulp(std::istream &in)
{
std::string ret;
char buffer[4096];
while (in.read(buffer, sizeof(buffer)))
ret.append(buffer, sizeof(buffer));
ret.append(buffer, in.gcount());
return ret;
}
我做了一些基准测试,事实证明std::istreambuf_iterator
技术(used by the accepted answer)实际上要慢得多。在带有-O3
的gcc 4.4.5上,它在我的机器上差异大约为4.5倍,并且随着优化设置的降低,差距变得更大。
答案 2 :(得分:16)
你可以做到
std::string s;
std::ostringstream os;
os<<stream.rdbuf();
s=os.str();
但我不知道它是否更有效率。
替代版本:
std::string s;
std::ostringstream os;
stream>>os.rdbuf();
s=os.str();
答案 3 :(得分:11)
您可以尝试使用算法中的内容。我必须为工作做好准备,但这里的事情非常快速(必须有更好的方法):
copy( istreambuf_iterator<char>(stream), istreambuf_iterator<char>(), back_inserter(s) );
答案 4 :(得分:0)
好吧,如果你正在寻找一种简单且“可读”的方式来做到这一点。我建议在项目中添加/使用一些高级框架。为此,我总是在我的所有项目中使用Poco和Boost。在这种情况下,使用Poco:
string text;
FileStream fstream(TEXT_FILE_PATH);
StreamCopier::copyToString(fstream, text);
答案 5 :(得分:0)
也许这是一行C ++ 11解决方案:
std::vector<char> s{std::istreambuf_iterator<char>{in},{}};
答案 6 :(得分:0)
将getline与分隔符一起使用会怎样?下一个代码可以帮助我使用g ++-10将整个std :: cin读入ubuntu上的字符串中。
#include <iostream>
#include <string>
using namespace std;
int main() {
string s;
getline(cin, s, {}); //the whole stream into variable s
return 0;
}