string容器
Posted 今天天气眞好
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了string容器相关的知识,希望对你有一定的参考价值。
文章目录
1 string基本概念
本质:
string是C++风格的字符串,而string本质上是一个类
string和char * 区别:
char * 是一个指针
string是一个类,类内部封装了char*,管理这个字符串,是一个char*型的容器。
特点:
string 类内部封装了很多成员方法
例如:查找find,拷贝copy,删除delete 替换replace,插入insert
string管理char*所分配的内存,不用担心复制越界和取值越界等,由类内部进行负责
2 string构造函数
构造函数原型:
string();
//创建一个空的字符串 例如: string str;
string(const char* s);
//使用字符串s初始化
string(const string& str);
//使用一个string对象初始化另一个string对象
string(int n, char c);
//使用n个字符c初始化
示例:
#include <iostream>
#include <string>
using namespace std;
//string构造
void test01()
{
string s1; //创建空字符串,调用无参构造函数
cout << "str1 = " << s1 << endl;
const char* str = "hello world";
string s2(str); //把c_string转换成了string
cout << "str2 = " << s2 << endl;
string s3(s2); //调用拷贝构造函数
cout << "str3 = " << s3 << endl;
string s4(10, 'a');
cout << "str3 = " << s3 << endl;
}
int main()
{
test01();
system("pause");
return 0;
}
运行结果:
总结:string的多种构造方式没有可比性,灵活使用即可
3 string赋值操作
功能描述:
给string字符串进行赋值
赋值的函数原型:
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赋给当前字符串
示例:
#include <iostream>
#include <string>
using namespace std;
void test()
{
string str1;
str1 = "hello world";
cout << "str1 = " << str1 << endl;
string str2;
str2 = str1;
cout << "str2 = " << str2 << endl;
string str3;
str3 = 'a';
cout << "str3 = " << str3 << endl;
string str4;
str4.assign("hello C++");
cout << "str4 = " << str4 << endl;
string str5;
str5.assign("hello C++",6);
cout << "str5 = " << str5 << endl;
string str6;
str6.assign(str4);
cout << "str6 = " << str6 << endl;
string str7;
str7.assign(6,'w');
cout << "str7 = " << str7 << endl;
}
int main()
{
test();
return 0;
}
运行结果:
总结:string的赋值方式很多,operator=
这种方式是比较实用的
4 string字符串拼接
功能描述:
实现在字符串末尾拼接字符串
函数原型:
string& operator+=(const char* str);
//重载+=操作符
string& operator+=(const char c);
//重载+=操作符
string& operator+=(const string& str);
//重载+=操作符
string& append(const char *s);
//把字符串s连接到当前字符串结尾
string& append(const char *s, int n);
//把字符串s的前n个字符连接到当前字符串结尾
string& append(const string &s);
//同operator+=(const string& str)
string& append(const string &s, int pos, int n);
//字符串s中从pos开始的n个字符连接到字符串结尾
示例:
#include <iostream>
#include <string>
using namespace std;
void test()
{
string str1 = "hello";
str1 += "world";
cout << "str1 = " << str1 << endl;
string str2 = "w";
str2 += "w";
cout << "str2 = " << str2 << endl;
string str3 = "hello";
str3 += str1;
cout << "str3 = " << str3 << endl;
string str4 = "hello";
str4.append("world");
cout << "str4 = " << str4 << endl;
string str5 = "hello";
str5.append("hello world",5);
cout << "str5 = " << str5 << endl;
string str6 = "hello";
str6.append(str5);
cout << "str6 = " << str6 << endl;
string str7 = "hello";
str7.append(str5,2,2);
cout << "str7 = " << str7 << endl;
}
int main()
{
test();
return 0;
}
运行结果:
总结:字符串拼接的重载版本很多,初学阶段记住几种即可
5 string查找和替换
功能描述:
查找:查找指定字符串是否存在
替换:在指定的位置替换字符串
函数原型:
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
示例:
#include <iostream>
#include <string>
using namespace std;
void test1()
{
string str1 = "huanggang";
int pos1 = str1.find(str1,0);
cout << pos1 << endl;
int pos2 = str1.find("gang",0);
cout << pos2 << endl;
int pos3 = str1.find("gg",0);
cout << pos3 << endl;
int pos4 = str1.find('g',2);
cout << pos4 << endl;
cout << endl;
//find 与 rfing的区别就是find时从左往右找
//rfing是从右往左找
string str2(str1);
int pos5 = str2.rfind(str2,9);
cout << pos5 << endl;
int pos6 = str2.rfind("gg",9);
cout << pos6 << endl;
int pos7 = str2.rfind("ang",9,2);
cout << pos7 << endl;
int pos8 = str2.rfind('g',9);
cout << pos8 << endl;
cout << endl;
}
void test2()
{
string str3 = "hello world";
str3.replace(4,3,"aaa");
cout << "str3 = " << str3 << endl;
}
int main()
{
test1();
test2();
return 0;
}
运行结果:
总结:
(1)find查找是从左往后,rfind从右往左
(2)find找到字符串后返回查找的第一个字符位置,找不到返回-1
(3)replace在替换时,要指定从哪个位置起,多少个字符,替换成什么样的字符串
6 string字符串比较
功能描述:
字符串之间的比较
比较方式:
字符串比较是按字符的ASCII码进行对比
= 返回 0
> 返回 1
< 返回 -1
函数原型:
int compare(const string &s) const;
//与字符串s比较
int compare(const char *s) const;
//与字符串s比较
示例:
#include <iostream>
#include <string>
using namespace std;
void test1()
{
string str1 = "abc";
int pos1 = str1.compare("acb");
cout << pos1 << endl;
string str2 = "acb";
int pos2 = str2.compare(str1);
cout << pos2 << endl;
}
int main()
{
test1();
return 0;
}
运行结果:
总结:字符串对比主要是用于比较两个字符串是否相等,判断谁大谁小的意义并不是很大
7 string字符存取
string中单个字符存取方式有两种
char& operator[](int n);
//通过[]方式取字符
char& at(int n);
//通过at方法获取字符
示例:
#include <iostream>
#include <string>
using namespace std;
void test()
{
string str = "huanggang";
for(int i = 0;i < str.size(); i++)
{
cout << str[i] << " ";
}
cout << endl;
for(int i = 0;i < str.size(); i++)
{
cout << str.at(i) << " ";
}
cout << endl;
//字符修改
str[0] = 'z';
str.at(1) = 'z';
cout << str << endl;
}
int main()
{
test();
return 0;
}
运行结果:
总结:string字符串中单个字符存取有两种方式,利用 [ ] 或 at
8 string插入和删除
功能描述:
对string字符串进行插入和删除字符操作
函数原型:
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个字符
示例:
#include <iostream>
#include <string>
using namespace std;
void test()
{
string str = "hello world";
string str1 = "xx";
str.insert(2,"aa");
cout << str << endl;
str.insert(4,str1);
cout << str << endl;
str.insert(8,3,'s');
cout << str << endl;
str.erase(2,5);
cout << str << endl;
}
int main()
{
test();
return 0;
}
运行结果:
总结:插入和删除的起始下标都是从0开始
9 string子串
功能描述:
从字符串中获取想要的子串
函数原型:
string substr(int pos = 0, int n = npos) const;
//返回由pos开始的n个字符组成的字符串
示例:
#include <iostream>
#include <string>
using namespace std;
void test()
{
string str = "abcdefg";
string s = str.substr(2,4);
cout << s << endl;
string email = "hello@sina.com";
int pos = email.find("@");
string username = email.substr(0, pos);
cout << username << endl;
}
int main()
{
test();
return 0;
}
运行结果:
总结:灵活的运用求子串功能,可以在实际开发中获取有效的信息
以上是关于string容器的主要内容,如果未能解决你的问题,请参考以下文章