「cpp/string/basic string」の版間の差分
(Import from dokuwiki) |
|||
(5人の利用者による、間の21版が非表示) | |||
1行: | 1行: | ||
− | {{title| | + | {{title| |
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | ++ | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | }} | ||
− | + | std | |
− | {| | + | {|=||[[ |
− | | | + | |
− | |[[ | + | |
− | | | + | |
− | | | + | |
− | | | + | |
− | | | + | string |
− | | | + | |
− | | | + | basic_string |
− | | | + | basic_string |
− | | | + | | |
− | | | + | | |
− | | | + | | |
− | | | + | | stringbasic_string |
− | | | + | | |
− | | | + | | |
− | | | + | | |
− | | | + | | basic_string |
− | | | + | |
− | | | + | |
− | | | + | |
− | + | ||
− | + | | | |
− | | | + | | |
− | | | + | | |
− | | | + | |
− | | | + | |
− | | | + | |
− | | | + | |
− | + | ||
− | | | + | |
− | | | + | |
− | | | + | | cpp//basic_string |
− | | | + | /| |
− | | | + | | | |
− | | | + | | cpp//basic_string |
− | | | + | /| |
− | | | + | | | |
− | + | | cpp//basic_string | |
− | | | + | /| |
− | | | + | | | |
− | | | + | | cpp//basic_string |
− | | | + | /| |
− | | | + | |
− | + | ||
− | + | ||
− | | | + | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | |
− | + | | | |
− | + | | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/data |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | |
− | | | + | | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/end |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | |
− | + | | | |
− | + | | cpp/string/basic_string/ | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | + | | | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | / |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | |
− | | | + | | |
− | | | + | | cpp/string/basic_string/ |
− | | | + | | |
− | + | | | |
− | + | | cpp/string/basic_string/ | |
− | | | + | | |
− | + | | | |
− | + | ||
− | + | | | |
− | + | | cpp/string/basic_string/ | |
− | | | + | |
− | |} | + | |
+ | |||
+ | |||
+ | | | ||
+ | | cpp/string/basic_string/ | ||
+ | | | ||
+ | | | ||
+ | |||
+ | | | ||
+ | | cpp/string/basic_string/ | ||
+ | | | ||
+ | |||
+ | | | ||
+ | | cpp/string/basic_string/ | ||
+ | | | ||
+ | | | ||
+ | | cpp/string/basic_string/ | ||
+ | | | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | | | ||
+ | | cpp/string/basic_string/ | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | | cpp/string/basic_string/ | ||
+ | |||
+ | |||
+ | [[cpp/string/basic_string/|]] | ||
+ | |||
+ | ||} |
2019年10月25日 (金) 07:55時点における最新版
ヘッダ <string> で定義
|
||
template< class CharT, |
(1) | |
namespace pmr { template <class CharT, class Traits = std::char_traits<CharT>> |
(2) | (C++17以上) |
クラステンプレート basic_string
は char ライクなオブジェクト (トリビアルな標準レイアウト型の非配列オブジェクト) の並びを格納したり操作したりします。 このクラスは文字の型やその型の操作の性質には依存しません。 操作は Traits
テンプレート引数で与えられる std::char_traits の特殊化またはそれと互換の特性クラスによって定義されます。 Traits::char_type
と CharT
は同じ型でなければならず、そうでなければプログラムは ill-formed です。
basic_string
の要素は隣接して格納されます,。 つまり、 basic_string
s
に対して、 [0, s.size())
の任意の n について &*(s.begin() + n) == &*s.begin() + n です。 別の言い方をすると、ヌル終端 (C++11以上) CharT[]
配列の最初の要素へのポインタを期待する関数に s[0]
へのポインタを渡すことができます。
std::basic_string
は AllocatorAwareContainer, SequenceContainer および ContiguousContainer (C++17以上) の要件を満たします。
一般的な文字型に対していくつかの typedef が提供されます。
ヘッダ
<string> で定義 | |
型 | 定義 |
std::string | std::basic_string<char> |
std::wstring | std::basic_string<wchar_t> |
std::u8string (C++20) | std::basic_string<char8_t> |
std::u16string (C++11) | std::basic_string<char16_t> |
std::u32string (C++11) | std::basic_string<char32_t> |
std::pmr::string (C++17) | std::pmr::basic_string<char> |
std::pmr::wstring (C++17) | std::pmr::basic_string<wchar_t> |
std::pmr::u8string (C++20) | std::pmr::basic_string<char8_t> |
std::pmr::u16string (C++17) | std::pmr::basic_string<char16_t> |
std::pmr::u32string (C++17) | std::pmr::basic_string<char32_t> |
目次 |
[編集] テンプレート引数
CharT | - | 文字型 |
Traits | - | 文字型の操作を指定する型特性クラス |
Allocator | - | 内部の記憶域を確保するために使用されるアロケータ型 |
[編集] メンバ型
メンバ型 | 定義 | ||||
traits_type
|
Traits
| ||||
value_type
|
CharT
| ||||
allocator_type
|
Allocator
| ||||
size_type
|
| ||||
difference_type
|
| ||||
reference
|
| ||||
const_reference
|
| ||||
pointer
|
| ||||
const_pointer
|
| ||||
iterator
|
LegacyRandomAccessIterator | ||||
const_iterator
|
const LegacyRandomAccessIterator | ||||
reverse_iterator
|
std::reverse_iterator<iterator> | ||||
const_reverse_iterator
|
std::reverse_iterator<const_iterator> |
[編集] メンバ関数
basic_string を構築します (パブリックメンバ関数) | |
デストラクタ |
内部の記憶域を解放し、文字列を破棄します (パブリックメンバ関数) |
文字列に値を代入します (パブリックメンバ関数) | |
文字列に文字を代入します (パブリックメンバ関数) | |
関連付けられているアロケータを返します (パブリックメンバ関数) | |
要素アクセス | |
境界チェック付きで指定された文字にアクセスします (パブリックメンバ関数) | |
指定された文字にアクセスします (パブリックメンバ関数) | |
(C++11) |
最初の文字にアクセスします (パブリックメンバ関数) |
(C++11) |
最後の文字にアクセスします (パブリックメンバ関数) |
文字列の最初の文字を指すポインタを返します (パブリックメンバ関数) | |
文字列の変更不可能な標準 C の文字配列バージョンを返します (パブリックメンバ関数) | |
(C++17) |
文字列全体に対する変更不可能な string_view を返します (パブリックメンバ関数) |
イテレータ | |
(C++11) |
先頭を指すイテレータを返します (パブリックメンバ関数) |
(C++11) |
終端を指すイテレータを返します (パブリックメンバ関数) |
(C++11) |
先頭を指す逆イテレータを返します (パブリックメンバ関数) |
(C++11) |
終端を指す逆イテレータを返します (パブリックメンバ関数) |
容量 | |
文字列が空かどうか調べます (パブリックメンバ関数) | |
文字数を返します (パブリックメンバ関数) | |
最大文字数を返します (パブリックメンバ関数) | |
記憶域を予約します (パブリックメンバ関数) | |
現在確保されている記憶域に保持することができる文字数を返します (パブリックメンバ関数) | |
(C++11) |
未使用のメモリを解放してメモリ使用量を減らします (パブリックメンバ関数) |
操作 | |
内容をクリアします (パブリックメンバ関数) | |
文字を挿入します (パブリックメンバ関数) | |
文字を削除します (パブリックメンバ関数) | |
文字を末尾に追加します (パブリックメンバ関数) | |
(C++11) |
最後の文字を削除します (パブリックメンバ関数) |
文字を末尾に追加します (パブリックメンバ関数) | |
文字を末尾に追加します (パブリックメンバ関数) | |
2つの文字列を比較します (パブリックメンバ関数) | |
(C++20) |
文字列が指定された接頭辞で始まるか調べます (パブリックメンバ関数) |
(C++20) |
文字列が指定された接尾辞で終わるか調べます (パブリックメンバ関数) |
文字列の指定された部分を置換します (パブリックメンバ関数) | |
部分文字列を返します (パブリックメンバ関数) | |
文字をコピーします (パブリックメンバ関数) | |
格納されている文字の数を変更します (パブリックメンバ関数) | |
内容を入れ替えます (パブリックメンバ関数) | |
検索 | |
文字列内の文字を探します (パブリックメンバ関数) | |
部分文字列が現れる最後の位置を探します (パブリックメンバ関数) | |
文字が現れる最初の位置を探します (パブリックメンバ関数) | |
文字が現れない最初の位置を探します (パブリックメンバ関数) | |
文字が現れる最後の位置を探します (パブリックメンバ関数) | |
文字が現れない最後の位置を探します (パブリックメンバ関数) | |
定数 | |
[静的] |
特殊な値です。正確な意味は文脈に依存します (パブリック静的メンバ定数) |
[編集] 非メンバ関数
2つの文字列または文字列と文字を連結します (関数テンプレート) | |
(C++20で削除)(C++20で削除)(C++20で削除)(C++20で削除)(C++20で削除)(C++20) |
2つの文字列を辞書的に比較します (関数テンプレート) |
std::swap アルゴリズムの特殊化 (関数テンプレート) | |
特定の基準を満たすすべての要素を削除します (関数テンプレート) | |
入出力 | |
文字列のストリーム入出力を行います (関数テンプレート) | |
入出力ストリームから文字列にデータを読み込みます (関数) | |
数値変換 | |
(C++11)(C++11)(C++11) |
文字列を符号付き整数に変換します (関数) |
(C++11)(C++11) |
文字列を符号なし整数に変換します (関数) |
(C++11)(C++11)(C++11) |
文字列を浮動小数点値に変換します (関数) |
(C++11) |
整数または浮動小数点値を string に変換します (関数) |
(C++11) |
整数または浮動小数点値を wstring に変換します (関数) |
[編集] リテラル
名前空間
std::literals::string_literals で定義 | |
(C++14) |
文字配列リテラルを basic_string に変換します (関数) |
[編集] ヘルパークラス
(C++11)(C++20)(C++11)(C++11)(C++11)(C++20)(C++20)(C++20)(C++20)(C++20) |
文字列に対するハッシュサポート (クラステンプレートの特殊化) |