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などの関数.
#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;
}