アプリが多くの割り当てを行う必要がないように、ostringstream(および基になるバッファー)をクリアして再利用したいと思います。オブジェクトを初期状態にリセットするにはどうすればよいですか?
57141 次
4 に答える
162
過去に一連の clear と str を使用しました。
// clear, because eof or other bits may be still set.
s.clear();
s.str("");
入力と出力の両方の文字列ストリームに対してこれが行われました。または、手動でクリアしてから、最初に適切なシーケンスをシークすることもできます。
s.clear();
s.seekp(0); // for outputs: seek put ptr to start
s.seekg(0); // for inputs: seek get ptr to start
str
これにより、現在出力バッファーにあるものを上書きすることで、再割り当てが行われるのを防ぐことができます。結果は次のようになります。
std::ostringstream s;
s << "hello";
s.seekp(0);
s << "b";
assert(s.str() == "bello");
C 関数に文字列を使用する場合は、次std::ends
のように終了 null を配置してを使用できます。
std::ostringstream s;
s << "hello";
s.seekp(0);
s << "b" << std::ends;
assert(s.str().size() == 5 && std::strlen(s.str().data()) == 1);
std::ends
std::strstream
スタックに割り当てた char 配列に直接書き込むことができた deprecated の遺物です。終端の null を手動で挿入する必要がありました。ただし、std::ends
非推奨ではありません。上記の場合と同様に、まだ有用であるためだと思います。
于 2009-03-08T21:08:38.750 に答える
6
ostr.str("")
呼び出しがうまくいくようです。
于 2009-03-08T21:01:43.150 に答える
2
最初に使用する前にバッファをクリアするような方法でバッファをクリアする場合は、最初にMSVCを使用してバッファに何かを追加する必要があります。
struct Foo {
std::ostringstream d_str;
Foo() {
d_str << std::ends; // Add this
}
void StrFunc(const char *);
template<class T>
inline void StrIt(const T &value) {
d_str.clear();
d_str.seekp(0); // Or else you'll get an error with this seek
d_str << value << std::ends;
StrFunc(d_str.str().c_str()); // And your string will be empty
}
};
于 2011-11-03T00:31:56.380 に答える
-2
あなたはそうしない。わかりやすくするために 2 つの異なる名前のストリームを使用し、最適化コンパイラに古いストリームを再利用できることを認識させます。
于 2009-03-08T21:04:01.680 に答える