String

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 << " ";
}
posted @   江寒雨  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示
主题色彩