string基本文字シーケンスコンテナ
C言語は毎日専用の文字列タイプを提供し、文字配列を通じて文字列を格納し、処理する必要がある.標準C++では、文字列クラスはC++STLによって実現される.stringは文字ベースのシーケンスコンテナであり、vectorベクトルのような内部線形構造を有し、文字がコンテナに1つずつ書き込まれ、最後にnull文字で終わる.stringは、従来のchar*文字配列と比較して、文字の追加、削除、置換、検索、比較などに豊富な関数を提供します.
stringオブジェクトの作成
主に以下の方法があります.
(1) string()
string s;
(2) string(conststring&s,size_type pos=0,size_type n=npos)
string s1;
string s2(s1);
(3) string(const char*)
char* cArray=”abc”;
string s(cArray);
文字の追加
文字の追加は主にpush_back、append、insertなどの関数.
文字の遍歴
stringの文字には、配列方式と反復器[逆反復をサポート]の2つの方法でアクセスできます.
文字の削除
文字の削除はerase関数とclear関数を使用して実現できます.
文字の置換
replace関数を使用すると、文字の置換が可能になります.
文字の検索
find、rfind、find_を利用first_of、find_first_not_of、find_last_of、find_last_not_ofなどの関数は文字の検索を実現することができて、文字列の位置を返して、見つからないで、-1を返します.
文字列の比較
compare関数を用いて比較を実現する.
その他の一般的な関数
stringコンテナの統計情報(length、size、empty、c_など)を与える他の関数もあります.strなど.
ここでは一部の関数を示しただけで、まだかなりの関数がリストされていません.具体的にはC++Referenceというサイトを参照してください.http://www.cplusplus.com/reference/string/string/、このサイトには様々な使い方が詳しくリストされています.
stringオブジェクトの作成
主に以下の方法があります.
(1) string()
string s;
(2) string(conststring&s,size_type pos=0,size_type n=npos)
string s1;
string s2(s1);
(3) string(const char*)
char* cArray=”abc”;
string s(cArray);
文字の追加
文字の追加は主にpush_back、append、insertなどの関数.
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1;
s1.push_back('a');
s1.push_back('b');
s1.push_back('c');
cout<<s1<<endl;
char* cArray="efgh";
string s2(cArray);
cout<<s2<<endl;
cout<<s1+s2<<endl;
cout<<s1.append(s2)<<endl;
string::iterator i;
i=s1.begin();
i++;
s1.insert(i,'8');
cout<<s1<<endl;
s1+=s2;
cout<<s1<<endl;
return 0;
}
文字の遍歴
stringの文字には、配列方式と反復器[逆反復をサポート]の2つの方法でアクセスできます.
#include<iostream>
#include<string>
using namespace std;
int main()
{
char* cArray="hello,world";
string s(cArray);
//
for(int i=0;i<s.size();i++)
{
cout<<s[i]<<endl;
}
//
string::reverse_iterator rbegin,rend;
rend=s.rend();
for(rbegin=s.rbegin();rbegin!=rend;rbegin++)
{
cout<<*rbegin<<endl;
}
return 0;
}
文字の削除
文字の削除はerase関数とclear関数を使用して実現できます.
#include<iostream>
#include<string>
using namespace std;
int main()
{
char* cArray="a1234567";
string s(cArray);
s.erase(s.begin());
cout<<s<<endl;//1234567
s.erase(s.begin()+2,s.end()-2);
cout<<s<<endl;//1267
s.erase(0,2);
cout<<s<<endl;//67
s.clear();
cout<<s<<endl;//
return 0;
}
文字の置換
replace関数を使用すると、文字の置換が可能になります.
#include<iostream>
#include<string>
using namespace std;
int main()
{
char* cArray="hello,boy!";
string s(cArray);
s.replace(6,3,"girl");
cout<<s<<endl;//hello,girl!
s.replace(10,1,1,'.');
cout<<s<<endl;//hello,girl.
s.replace(s.begin(),s.begin()+5,"good morning");
cout<<s<<endl;//good morning,girl.
return 0;
}
文字の検索
find、rfind、find_を利用first_of、find_first_not_of、find_last_of、find_last_not_ofなどの関数は文字の検索を実現することができて、文字列の位置を返して、見つからないで、-1を返します.
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s("dog bird chicken bird cat");
//
cout<<s.find("bird")<<endl;// 4
cout<<(int)s.find("fish")<<endl;//-1
//
cout<<s.find('i',0)<<endl;//5
//
cout<<s.rfind("bird")<<endl;//17
//
cout<<s.rfind('i')<<endl;//18
//
cout<<s.find_first_of("33r97")<<endl;//6
//
cout<<s.find_first_not_of("dog bird")<<endl;//9
//
cout<<s.find_last_of("r")<<endl;//19
//
cout<<s.find_last_not_of("tea")<<endl;//22
return 0;
}
文字列の比較
compare関数を用いて比較を実現する.
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1("abcdef");
string s2("abc");
cout<<s1.compare("abcdef")<<endl;// , 0
cout<<s1.compare(s2)<<endl;//s1>s2,
cout<<s1.compare("aby")<<endl;//s1<"aby" , -1
cout<<s1.compare(0,3,s2)<<endl;//s1 3 s2, 0
return 0;
}
その他の一般的な関数
stringコンテナの統計情報(length、size、empty、c_など)を与える他の関数もあります.strなど.
ここでは一部の関数を示しただけで、まだかなりの関数がリストされていません.具体的にはC++Referenceというサイトを参照してください.http://www.cplusplus.com/reference/string/string/、このサイトには様々な使い方が詳しくリストされています.
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s;
cout<<s.empty()<<endl;// , 1
s+="1234567";
cout<<s.empty()<<endl;//0
cout<<s.length()<<endl;//7
cout<<s.size()<<endl;//7
const char* cArray=s.c_str();// string
cout<<cArray[2]<<endl;//3
return 0;
}