STL--string(1)

1.string使用之前的准备

1
2
#include <string> 
using namespace std;

2.string的构造函数

复制代码
 1 #include <string>
 2 using namespace std;
 3 
 4 void main()
 5 {
 6     string s1; string s2;    //默认构造函数:
 7 
 8     string s1(s2);            //拷贝构造函数
 9     
10     string strA("UIPower");    //带参数的构造函数:
11     string strB(5,'A');        //"AAAAA"
12 }
复制代码

3.string的存取字符操作

复制代码
 1 #include <string>
 2 using namespace std;
 3 
 4 void main()
 5 {
 6     string strA("I love china.");
 7 
 8     /*
 9     const char &operator[] (int n) const;
10     const char &at(int n) const;
11     */
12     char c = strA[3];
13     char d = strA.at(5);
14 }
复制代码

str.at(50)越界,抛出out_of_range异常, 可用try{}catch{}捕获 str[50]越界,编译器直接报错,不可以用try{}catch{}捕获

4.从string取得const char*的操作

1     string strA("I love china.");
2     const char *cpch = strA.c_str();

5.把string拷贝到char*指向的内存空间的操作

复制代码
1 #include <string>
2 using namespace std;
3 
4 void main()
5 {
6     string strA("I love china!");
7     char e[15] = {0};                        //申请空间
8     int iCount = strA.copy(e, 20, 0);        //iCount==13;
9 }
复制代码

int copy(char *s, int n, int pos=0) const;  把当前串中以pos(即第pos+1个)开始的n个字符拷贝到以s为起始位置的字符数组中,返回实际拷贝的数目。注意要保证s所指向的空间足够大以容纳当前字符串,不然会越界。

6.string的赋值

string &operator=(const string &s);//把字符串s赋给当前的字符串 string &assign(const char *s); //把字符串s赋给当前的字符串 string &assign(const char *s, int n); //把字符串s的前n个字符赋给当前的字符串 string &assign(const string &s);  //把字符串s赋给当前字符串 string &assign(int n,char c);  //用n个字符c赋给当前字符串 string &assign(const string &s,int start, int n);  //把字符串s中从start开始的n个字符赋给当前字符串

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <string>
 
using namespace std;
 
void main()
{
    string strA = "123456789";
    string strC;   
 
    strC = strA;                    //strC:123456789
    strC.assign("HuaWei");          //strC:HuaWei
    strC.assign(strA);              //strC:123456789
    strC.assign(5,'A');             //strC:AAAAA
    strC.assign(strA,2,3);          //strC:345
}

 

7.string的连接

string &operator+=(const string &s);  //把字符串s连接到当前字符串结尾 string &operator+=(const char *s);//把字符串s连接到当前字符串结尾 string &append(const char *s);    //把字符串s连接到当前字符串结尾 string &append(const char *s,int n);  //把字符串s的前n个字符连接到当前字符串结尾 string &append(const string &s);   //同operator+=() string &append(const string &s,int pos, int n);//把字符串s中从pos开始的n个字符连接到当前字符串结尾 string &append(int n, char c);   //在当前字符串结尾添加n个字符c

复制代码
 1 #include <string>
 2 
 3 using namespace std;
 4 
 5 void main()
 6 {
 7     string strA = "world!"; 
 8     string strD("Hello ");
 9 
10     strD += strA;                     //strD: Hello world!
11     strD += "Hello";                //strD:    Hello world!Hello
12     strD.append("Hello");            //strD: Hello world!Hello|Hello
13     strD.append("Hello", 3);        //strD: Hello world!HelloHelloHel
14     strD.append(strA);                //strD: Hello world!HelloHelloHelworld!
15     strD.append(strA,0,3);            //strD: Hello world!HelloHelloHelworld!wor
16     strD.append(5,'A');                //strD: Hello world!HelloHelloHelworld!worAAAAA
17 }
复制代码

8.string的比较

int compare(const string &s) const;  //与字符串s比较 int compare(const char *s) const;   //与字符串s比较 compare函数在>时返回 1,<时返回 -1,==时返回 0。比较区分大小写,比较时参考字典顺序,排越前面的越小。大写的A比小写的a小。

9.string的子串

string substr(int pos=0, int n=npos) const;    //返回由pos开始的n个字符组成的子字符串

string strA = "0123456789";
string strE = strA.substr(2, 4);   //此时strE内容为  "2345"

10.string的查找

int find(char c,int pos=0) const;  //从pos开始查找字符c在当前字符串的位置 int find(const char *s, int pos=0) const;  //从pos开始查找字符串s在当前字符串的位置 int find(const string &s, int pos=0) const;  //从pos开始查找字符串s在当前字符串中的位置 find函数如果查找不到,就返回-1

int rfind(char c, int pos=npos) const;   //从pos开始从后向前查找字符c在当前字符串中的位置 int rfind(const char *s, int pos=npos) const; int rfind(const string &s, int pos=npos) const; rfind是反向查找的意思,如果查找不到, 返回-1

复制代码
 1 #include <string>
 2 
 3 using namespace std;
 4 
 5 void main()
 6 {
 7     string strA = "0123456789"; 
 8 
 9     int iPos = strA.find('8',0);    //此时iPos为8,函数的第二个参数可不写
10     iPos = strA.find("789",0);        //此时iPos为7,函数的第二个参数可不写
11     string strF = "23";  
12     iPos = strA.find(strF,0);        //此时iPos为2,函数的第二个参数可不写
13 
14     iPos = strA.rfind('9',10);      //此时iPos为9,函数的第二个参数可不写
15     iPos = strA.rfind("789", 9);    //此时iPos为7,函数的第二个参数可不写
16     string strE("456");
17     iPos = strA.rfind(strE);        //此时iPos为4,函数的第二个参数可不写
18 }
复制代码

11.string的删除

string &erase(int pos=0, int n=npos);  //删除pos开始的n个字符,返回修改后的字符串

12string的替换

string &replace(int pos, int n, const char *s);//删除从pos开始的n个字符,然后在pos处插入串s string &replace(int pos, int n, const string &s);  //删除从pos开始的n个字符,然后在pos处插入串s void swap(string &s2);    //交换当前字符串与s2的值

1 string strF("abcdefg");
2 strF.replace(1,3,"xyzxyz");       //此时strF的内容为  "axyzxyzefg"

13.string与wstring

1)string与wstring的区别

  • string是对char*的管理,一个字符只占一个字节大小。一个汉字占两个字节,ASCII编码。
  • wstring是对wchar_t*的管理,一个字符占两个字节大小,一个汉字占两个字节,Unicode编码。
  • wstring的使用方法跟string类似,区别主要在于函数参数char*与函数参数wchar_t*

2)string与wstring的转换

  • 第一种方法: 调用Windows的API函数:WideCharToMultiByte()函数和MultiByteToWideChar()函数。
  • 第二种方法: 使用ATL的CA2W类与CW2A类。或使用A2W宏与W2A宏。
  • 第三种方法: 跨平台的方法,使用CRT库的mbstowcs()函数和wcstombs()函数,需设定locale。

方法三:

复制代码
 1 #include <string>
 2 #include <locale.h>
 3 using namespace std;
 4 
 5 //wstring转成string
 6 string ws2s(const wstring &ws)
 7 {
 8     string curLocale = setlocale(LC_ALL,NULL);  //curLocale="C";
 9     setlocale(LC_ALL,"chs");
10     const wchar_t * _Source=ws.c_str();
11     size_t _Dsize=2*ws.size()+1;
12     char * _Dest = new char[_Dsize];
13     memset(_Dest,0,_Dsize);
14     wcstombs(_Dest,_Source,_Dsize);
15     string result = _Dest;
16     delete[] _Dest;
17     setlocale(LC_ALL,curLocale.c_str());
18 
19     return result;
20 }
复制代码

3)编码统一化,编写单一源代码

      如果我们想建立两个版本的程序,一个处理ASCII字符串,另一个处理Unicode字符串,最好的解决办法是编写出既能按ASCII编译又能按Unicode编译的单一源代码。把以下代码加入到程序中,只要修改一个宏就能满足我们的要求。

复制代码
1 #ifdef _UNICODE
2 typedef wstring  tstring;
3 typedef wchar_t  tchar;
4 #define _T(x)  L ## x
5 #else
6 typedef string tstring;
7 typedef char tchar;
8 #define _T(x) x
9 #endif
 
posted on 2013-08-06 22:32  奎哥  阅读(230)  评论(0编辑  收藏  举报