string容器(重点)
1.数据结构:连续的存储空间,用一个char*指向这片空间
2.迭代器:随机访问迭代器
3.常用的api:
1.构造
string();//创建一个空的字符串 例如: string str;
string(const string& str);//使用一个string对象初始化另一个string对象
string(const char* s);//使用字符串s初始化
string(int n, char c);//使用n个字符c初始化
2.基本赋值
string& operator=(const char* s);//char*类型字符串 赋值给当前的字符串
string& operator=(const string&s);//把字符串 s 赋给当前的字符串
string& operator=(char c);//字符赋值给当前的字符串
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 个字符赋值给字符串,
如 s=hello,那么 n=3,start=1,那么是 hel 中从 e 开始赋值 3-1 个字符
3.存取字符
char& operator[](int n);//通过[]方式取字符 越界不抛异常 直接挂
char& at(int n);//通过at方法获取字符 越界会抛异常
4.拼接
string& operator+=(const string& str);//重载+=操作符
string& operator+=(const char* str);//重载+=操作符
string& operator+=(const char c);//重载+=操作符
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
5.查找和替换
int find(const string& str, int pos = 0) const; //查找str第一次出现位置,从pos开始查找
int find(const char* s, int pos = 0) const; //查找s第一次出现位置,从pos开始查找
int find(const char* s, int pos, int n) const; //从pos位置查找s的前n个字符第一次位置
int find(const char c, int pos = 0) const; //查找字符c第一次出现位置
int rfind(const string& str, int pos = npos) const;//查找str最后一次位置,从pos开始查找
int rfind(const char* s, int pos = npos) const;//查找s最后一次出现位置,从pos开始查找
int rfind(const char* s, int pos, int n) const;//从pos查找s的前n个字符最后一次位置
int rfind(const char c, int pos = 0) const; //查找字符c最后一次出现位置
string& replace(int pos, int n, const string& str); //替换从pos开始n个字符为字符串str
string& replace(int pos, int n, const char* s); //替换从pos开始的n个字符为字符串s
6.比较
/*
compare函数在>时返回 1,<时返回 -1,==时返回 0。
比较区分大小写,比较时参考字典顺序,排越前面的越小。
大写的A比小写的a小。
*/
int compare(const string& s) const;//与字符串s比较
int compare(const char *s) const;//与字符串s比较
7.子串
string substr(int pos = 0, int n = npos) const;//返回由pos开始的n个字符组成的字符串 npos是最后的位置
8.插入和删除
string& insert(int pos, const char* s); //插入字符串
string& insert(int pos, const string& str); //插入字符串
string& insert(int pos, int n, char c);//在指定位置插入n个字符c
string& erase(int pos, int n = npos);//删除从Pos开始的n个字符 npos是最后的位置
9.string和const char*转换
//string 转 char*
string str = "itcast";
const char* cstr = str.c_str();
//char* 转 string
char* s = "itcast";
string sstr(s);
const char* s = "hello";
string str = string(s)
4.常用的api中的注意:
1.[]和at区别:[]如果越界,不抛异常,直接挂。at会抛异常
2.字符串内存重新分配,[]和at获取的字符引用,再次使用时,可以能会出错
3.string和char *的区别:string是一个类,char *是一个指针
void test10()
{
string s = "abcde";
char &a = s[2];
char &b = s[3];
a = '1';
b = '2';
cout << "a:" << a << endl;
cout << "b:" << b << endl;
cout << s << endl;
cout << "字符串的原空间地址:" << (int*)s.c_str() << endl; //分配在栈中
s = "fdasfdasfdsafdasherewrkewhsaferew"; //大于字节会分配到堆中
cout << "字符串的空间地址:" << (int*)s.c_str() << endl;
//原空间被释放,但是a还是被释放的s[2]空间的别名,如果操作非法的空间,会出错
//a = '3';
}
字符串迭代
void test10()
{
string s = "abcde";
//迭代
for (string::iterator it = s.begin(); it != s.end(); ++it)
cout << *it << " ";
//反向迭代
for (string::reverse_iterator it = s.rbegin(); it != s.rend(); ++it)
cout << *it << " ";
}
标签:const,String,int,pos,char,字符串,string
From: https://www.cnblogs.com/wbcde116/p/18023588