basic_string::basic_string
空特定の文字で初期化のラッパを構築するまたは別の文字列オブジェクトまたは C スタイルの (NULL で終わる) 文字列の全体または一部を文字列のコピーです。
basic_string();
explicit basic_string(
const allocator_type& _Al
);
basic_string(
const basic_string& _Right
);
basic_string(
basic_string&& _Right
);
basic_string(
const basic_string& _Right,
size_type _Roff,
size_type _Count = npos
);
basic_string(
const basic_string& _Right,
size_type _Roff,
size_type _Count,
const allocator_type& _Al
);
basic_string(
const value_type *_Ptr,
size_type _Count
);
basic_string(
const value_type *_Ptr,
size_type _Count,
const allocator_type& _Al
);
basic_string(
const value_type *_Ptr
);
basic_string(
const value_type *_Ptr,
const allocator_type& _Al
);
basic_string(
size_type _Count,
value_type _Ch
);
basic_string(
size_type _Count,
value_type _Ch,
const allocator_type& _Al
);
template <class InputIterator>
basic_string(
InputIterator _First,
InputIterator _Last
);
template <class InputIterator>
basic_string(
InputIterator _First,
InputIterator _Last,
const allocator_type& _Al
);
basic_string(
const_pointer _First,
const_pointer _Last
);
basic_string(
const_iterator _First,
const_iterator _Last
);
パラメーター
_Ptr
構築 string の初期化に使用される文字が C 文字列。この値が null ポインターであることはできません。_Al
構築された文字列オブジェクトの領域のアロケーター クラス。_Count
初期化する文字数。_Right
構築された文字列を初期化文字列。_Roff
構築された文字列の文字値を初期化するために使用される 1 番目の文字列の文字のインデックス。_Ch
構築された文字列にコピーする文字です。_First
挿入するソース範囲内の先頭の要素を示す入力反復子const_pointerまたは const_iterator。_Last
挿入するソース範囲内の最後の要素の次の要素の位置を示す入力反復子const_pointerまたは const_iterator。
戻り値
コンストラクターによって構築される文字列オブジェクトへの参照。
解説
すべてのコンストラクターは basic_string::allocator_type を保存し被制御シーケンスを初期化します。アロケーター オブジェクトは引数 al ある場合です。コピー コンストラクターでは right.basic_string::get_allocator() です。それ以外の場合は Alloc() です。
被制御シーケンスは残りのオペランドで指定されたオペランド シーケンスのコピーに初期化されます。オペランドの順序なしのコンストラクターは空の初期被制御シーケンスを指定します。InputIterator がテンプレートのコンストラクターの整数型である場合オペランド シーケンスの _First, _Last は (size_type)_First, (value_type)_Last と同様に動作します。
使用例
// basic_string_ctor.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
// The first member function initializing with a C-string
const char *cstr1a = "Hello Out There.";
basic_string <char> str1a ( cstr1a , 5);
cout << "The string initialized by C-string cstr1a is: "
<< str1a << "." << endl;
// The second member function initializing with a string
string str2a ( "How Do You Do?" );
basic_string <char> str2b ( str2a , 7 , 7 );
cout << "The string initialized by part of the string cstr2a is: "
<< str2b << "." << endl;
// The third member function initializing a string
// with a number of characters of a specific value
basic_string <char> str3a ( 5, '9' );
cout << "The string initialized by five number 9s is: "
<< str3a << endl;
// The fourth member function creates an empty string
// and string with a specified allocator
basic_string <char> str4a;
string str4b;
basic_string <char> str4c ( str4b.get_allocator( ) );
if (str4c.empty ( ) )
cout << "The string str4c is empty." << endl;
else
cout << "The string str4c is not empty." << endl;
// The fifth member function initializes a string from
// another range of characters
string str5a ( "Hello World" );
basic_string <char> str5b ( str5a.begin ( ) + 5 , str5a.end ( ) );
cout << "The string initialized by another range is: "
<< str5b << "." << endl;
}
出力
The string initialized by C-string cstr1a is: Hello.
The string initialized by part of the string cstr2a is: You Do?.
The string initialized by five number 9s is: 99999
The string str4c is empty.
The string initialized by another range is: World.
必要条件
ヘッダー : <string>
名前空間: std