basic_string<CharT, Traits, Allocator> str() const; // (1) C++03
basic_string<CharT, Traits, Allocator> str() const &; // (1) C++20
template <class SAlloc>
basic_string<CharT, Traits, SAlloc> str(const SAlloc& sa) const; // (2) C++20
basic_string<CharT, Traits, Allocator> str() &&; // (3) C++20
void str(const basic_string<CharT, Traits, Allocator>& s); // (4) C++03
template <class SAlloc>
void str(const basic_string<CharT, Traits, SAlloc>& s); // (5) C++20
void str(const basic_string<CharT, Traits, Allocator>&& s); // (6) C++20
template<class T>
void str(const T& t); // (7) C++26
概要
文字列オブジェクトを取得または設定する。
書き込み位置としては先頭にリセットされるため注意すること。
- (1) : 文字列オブジェクトを取得する
- (2) : 文字列オブジェクトを取得して、
SAlloc型のアロケータsaによって確保する - (3) : 保持する文字列オブジェクトをムーブして取得する
- (4) : 文字列オブジェクト
sを設定する - (5) :
Allocatorに変換可能なSAlloc型のアロケータによって確保されているデータをコピーして、文字列オブジェクトsを設定する - (6) : 与えられた文字列オブジェクト
sをムーブして設定する - (7) :
std::basic_string_viewに変換可能な文字列を設定する
テンプレートパラメータ制約
- (7) :
is_convertible_v<const T&, basic_string_view<CharT, Traits>>がtrueであること
効果
- (1) :
return rdbuf()->str()と等価 - (2) :
return rdbuf()->str(sa)と等価 - (3) :
return std::move(*rdbuf()).str()と等価 - (4) :
rdbuf()->str(s)と等価 - (5) :
rdbuf()->str(s)と等価 - (6) :
rdbuf()->str(std::move(s))と等価 - (7) :
rdbuf()->str(t)と等価
例
基本的な使い方
#include <iostream>
#include <sstream>
#include <string>
int main()
{
// 文字列の取得
std::ostringstream oss;
oss << "Hello " << 123 << " World";
std::cout << "Content: " << oss.str() << std::endl;
// 追記モード
oss << " + more";
std::cout << "After append: " << oss.str() << std::endl;
// 新しい文字列を設定(内容を置き換える)
oss.str("Reset content");
std::cout << "After reset: " << oss.str() << std::endl;
// 書き込み位置は先頭にリセットされる
oss << "!!";
std::cout << "After write: " << oss.str() << std::endl;
// 空文字列でクリア
oss.str("");
oss << "Fresh start";
std::cout << "Final: " << oss.str() << std::endl;
}
出力
Content: Hello 123 World
After append: Hello 123 World + more
After reset: Reset content
After write: !!set content
Final: Fresh start
ムーブを使用する例 (C++20)
#include <iostream>
#include <sstream>
int main() {
std::ostringstream ss;
// ムーブして文字列を設定
std::string s = "Move string";
ss.str(std::move(s));
ss.seekp(0, std::ios_base::end); // 書き込み位置を末尾に移動
ss << " more";
std::cout << ss.str() << std::endl;
// ムーブで文字列を取得
std::string r = std::move(ss).str();
std::cout << r << std::endl;
}
出力
Move string more
Move string more
string_viewからの設定 (C++26)
#include <iostream>
#include <sstream>
#include <string_view>
int main() {
std::ostringstream ss;
// 文字列リテラルを設定
ss.str("set from string literal");
ss.seekp(0, std::ios_base::end); // 書き込み位置を末尾に移動
ss << " test";
std::cout << ss.str() << std::endl;
// string_viewを設定
std::string_view sv = "set from string_view";
ss.str(sv);
ss.seekp(0, std::ios_base::end); // 書き込み位置を末尾に移動
ss << " test";
std::cout << ss.str() << std::endl;
}
出力
set from string literal test
set from string_view test