C++string类用法

1.string类的输入操作(string类重载运算符operator>>用于输入,同样重载运算符operator<<用于输出操作)

operator是C++的关键字,它和运算符一起使用,表示一个运算符函数,理解时应将operator=整体上视为一个函数名。 这是C++扩展运算符功能的方法。关于operator的更多内容不在这里详细说明

string str1;  
    cin >> str1;     //当用cin>>进行字符串的输入的时候,遇到空格的地方就停止字符串的读取输入

cin.get();           //与getchar()作用相似

getline (cin, str);    //字符串的行输入(读取一行包含空格的字符串,遇到回车换行结束)

getline (cin, str,'!');  //输入一行字符,赋给str,并且以'!'结束
 

2.string类的初始化操作

string str = "hello world!";
string str ("hello world!");
string str1 (str,6);           //=="world!" //表示取出从第6位开始到结尾的字符串

string str2 (str,6,2);         //=="wo"  //表示从第6位开始取出2位字符串

char s[]={"how are you!"};
string str3 = s;                 //这是允许的

string str4 (s);
string str5 (s,3);             //=="how"

string str6 (s+4,s+6);         //=="are"

string str7 (5,"i");           //=="iiiii" //表示5个'i'的字符串

str7.~string();                //销毁字符串,释放内存

3.string类的字符与字符串操作
string str = "abcdef";
char ch = str[0];     
char ch = str.at[0];//=='a' //返回第n个字符(如果越界会发生抛出异常)

string str1 = "How are you?";
string str2 = "I'm fine";
string str = str1+str2;
str1 += str2;               //将2个字符串拼接

str.push_back('.');         //在字符串尾部加上'.'字符

str.append("And you?");     //在字符串尾部加上"And you?"字符串 

str.append(s);    //把char类型字符串s连接到当前字符串的结尾   

str.append(s, 2);    //把char类型字符串s的前2个字符连接到当前字符串的结尾  

str.append(str1.begin(), str1.end());//把迭代器之间的一段字符连接到当前字符串的结尾   

str.push_back('k');    //把一个字符连接到当前字符串的结尾 

str.assign("hello");        //重新赋值(也可以是char字符数组,string型的字符串)

str.assign(str1);
char s[]={"eee"};
str.assign(s);    

str.assign(s, 2);     //用char类型字符串s开始的n个字符赋值

str.assign(len, ch);     //用len个字符ch赋值给当前字符串

str.assign(str1, 0, 3);      //把字符串str1中从0开始的3个字符赋给当前字符串

str.insert(1,"ee");          //在指定位置后面插入字符串

string str1 = "0123456789";  
str.assign(str1.begin(), str1.end());//把迭代器之间的字符赋给字符串  

4.string类的特性描述

string str="abcdef";
int size;

size = str.capacity();   //返回当前容量

size = str.max_size();   //返回string对象中可存放的最大字符串的长度 

size = str.size();       //返回当前字符串的大小

size = str.length();     //返回当前字符串的长度   //C++中str.length()与str,size()没区别。

bool flag;  
    flag = str.empty();  //判断当前字符串是否为空 

int len = 10;   
    str.resize(len, ch);//把字符串当前大小置为len,并用字符ch填充不足的部分


5.string的比较
比较操作 ==  !=  >  >=  <  <=  compare

== != > >= < <=       //可以直接用来比较字符串

string str1 = "abc";
string str2 = "acd";
string str3 = "ccc";

str1.compare("abc");  //相等返回0,大于返回正数,小于返回负数

str1.compare(str2);

str2.compare(1,1,"c",1); // c==c 返回0

str2.compare(1,2,str3,2,1) // cd与c比较

//用法:比较str1字符串从a开始的b个字符组成的字符串与str2字符串从c开始的d个字符组成的字符串的大小

6.string的字串 

string str;  
    str1 = str.substr(10, 15);//返回从下标10开始的15个字符组成的字符串


7.string的交换  

    str.swap(str1);//交换str1与str的值  


8.string的查找

查找成功时返回所在位置,失败时返回string::npos的值,即是-1   
string str1 = "abcdefghijklmnopqrstuvwxyz";  
    int pos;  
pos = str1.find('i', 0);//从位置0开始查找字符i在当前字符串的位置   

pos = str1.find("ghijk", 0);//从位置0开始查找字符串“ghijk”在当前字符串的位置   

pos = str1.find("opqrstuvw", 0, 4);//从位置0开始查找字符串“opqrstuvw”前4个字符组成的字符串在当前字符串中的位置   

pos = str1.rfind('s', string::npos);//从字符串str1反向开始查找字符s在字符串中的位置   
 
pos = str1.rfind("klmn", string::npos);//从字符串str1反向开始查找字符串“klmn”在字符串中的位置   
  
pos = str1.rfind("opqrstuvw", string::npos, 3);//从string::pos开始从后向前查找字符串s中前n个字符组成的字符串在当前串中的位置   

string str = "aaaabbbbccccdddeeefffggghhhiiijjjkkllmmmandjfaklsdfpopdtwptioczx";  

pos = str.find_first_of('d', 0);//从位置0开始查找字符d在当前字符串第一次出现的位置

pos = str.find_first_of("eefff", 0);//从位置0开始查找字符串“eeefff“在当前字符串中第一次出现的位置   

pos = str.find_first_of("efff", 0, 3);//从位置0开始查找当前串中第一个在字符串”efff“的前3个字符组成的数组里的字符的位置   

pos = str.find_first_not_of('b', 0);//从当前串中查找第一个不在串s中的字符出现的位置   
  
pos = str.find_first_not_of("abcdefghij", 0);//从当前串中查找第一个不在串s中的字符出现的位置   

pos = str.find_first_not_of("abcdefghij", 0, 3);//从当前串中查找第一个不在由字符串”abcdefghij”的前3个字符所组成的字符串中的字符出现的位置

  //下面的last的格式和first的一致,只是它从后面检索!   
pos = str.find_last_of('b', string::npos);  

pos = str.find_last_of("abcdef", string::npos);  
 
pos = str.find_last_of("abcdef", string::npos, 2);  
  
pos = str.find_last_not_of('a', string::npos);  
  
pos = str.find_last_not_of("abcdef", string::npos);  

pos = str.find_last_not_of("abcdef", string::npos, 3);  

9.string的替换   
string str = "abcdefghijklmn";  
str.replace(0, 3, "qqqq");//删除从0开始的3个字符,然后在0处插入字符串“qqqq”   

str.replace(0, 3, "vvvv", 2);//删除从0开始的3个字符,然后在0处插入字符串“vvvv”的前2个字符   
  
str.replace(0, 3, "opqrstuvw", 2, 4);//删除从0开始的3个字符,然后在0处插入字符串“opqrstuvw”从位置2开始的4个字符   
  
str.replace(0, 3, 8, 'c');//删除从0开始的3个字符,然后在0处插入8个字符 c   

//上面的位置可以换为迭代器的位置,操作是一样的,在这里就不再重复了!   
      
10.string的插入,下面的位置处亦可以用迭代器的指针表示,操作是一样的   
string str = "abcdefg";  
str.insert(0, "mnop");//在字符串的0位置开始处,插入字符串“mnop”   
   
str.insert(0, 2, 'm');//在字符串的0位置开始处,插入2个字符m   
  
str.insert(0, "uvwxy", 3);//在字符串的0位置开始处,插入字符串“uvwxy”中的前3个字符   

str.insert(0, "uvwxy", 1, 2);//在字符串的0位置开始处,插入从字符串“uvwxy”的1位置开始的2个字符    

     
11.string的删除  

string str = "gfedcba";  
string::iterator it;  
it = str.begin();  
it++;  
str.erase(it);//删除it指向的字符,返回删除后迭代器的位置   

str.erase(it, it+3);//删除it和it+3之间的所有字符,返回删除后迭代器的位置   
 
str.erase(2);//删除从字符串位置3以后的所有字符,返回位置3前面的字符   

12.字符串的流处理  

string str("hello,this is a test");  

istringstream is(str);  

string s1,s2,s3,s4;  

is>>s1>>s2>>s3>>s4;//s1="hello,this",s2="is",s3="a",s4="test"  

ostringstream os;  
os<<s1<<s2<<s3<<s4;  

cout<<os.str() << endl;  

posted @ 2017-06-01 20:21  Zireael  阅读(328)  评论(0编辑  收藏  举报