1、string(const char *s) :将 string 对象初始化为 s 指向的字符串:
string str("hello");
也可以使用c语言风格
string str = "hello!";
2、string(size_type n,char c) :创建一个包含 n 个元素的 string 对象,其中每个元素都被初始化为字符 c
string str(10,'a');
3、string(const string &str) :将一个 string 对象初始化为 string 对象 str(复制构造函数)
(1)string str("abcde");
(2)string str2(str);
4、获取string对象的长度,C语言中使用strlen()来获取字符串长度,C++中使用str.size()或str.length().
int len = str.size();
int len = str.length();
5、将一个 string 对象赋值给另一个 string 对象,或者用两个对象进行拼接再赋值,或者使用str.append()函数
string str1 = "hello";
string str2 = "world";
str1 = str1 + str2;
str1 += str2;
str1.append(str1);
6、string.push_back() 函数来在一个 string 对象后面附加一个字符
str.push_back('a');
7、对于string对象的比较,可以直接使用关系运算符。
if(str == ptr) {};
8、string对象的比较也可以使用string.compare() 方法
int compare(const string&str) const;
int compare(size_t pos,size_t len,const string&str)const;
int compare(size_t pos,size_t len,const string&str, size_t subpos,size_t sublen)const;
int compare(const char * s)const;
int compare(size_t pos,size_t len,const char * s)const;
int compare(size_t pos,size_t len,const char * s,size_t n)const;
// example
string str1("hello world");
string str2("hello boy");
str1.compare(6, 3, str2, 6, 3);
9、使用 string.substr() 函数来获取子串
string str2 = str.substr(3,2)
10、访问 string 字符串的元素
str[i];//不检查越界
str.at(i) //做越界检查
11、使用 string.find() 方法查找字符
// 从字符串的 pos 位置开始(若不指定 pos 的值,则默认从索引 0 处开始),查找子字符串 str。
// 如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回 string::npos:
// string 类将 npos 定义为保证大于任何有效下标的值。
size_type find (const string& str, size_type pos = 0) const;
size_type find (const char *s, size_type pos = 0) const;
size_type find (const char *s, size_type pos, size_type n);
size_type find (char ch, size_type pos = 0) const;
size_type(为下标);
12、string.rfind() 与 string.find() 方法类似,只是查找顺序不一样, string.rfind() 是从指定位置 pos (默认为字符串末尾)开始向前查找,直到字符串的首部,并返回第一次查找到匹配项时匹配项首字符的索引。换句话说,就是查找子字符串或字符最后一次出现的位置。
string.find_first_of() 方法在字符串中从指定位置开始向后(默认为索引 0 处)查找参数中任何一个字符首次出现的位置
string.find_last_of() 方法在字符串中查找参数中任何一个字符最后一次出现的位置
string.find_first_not_of() 方法在字符串中查找第一个不包含在参数中的字符
string.find_last_not_of() 方法在字符串中查找最后一个不包含在参数中的字符
13、使用 string.insert() 进行插入操作
string& insert(size_t pos,const string&str);
// 在位置 pos 处插入字符串 str
string& insert(size_t pos,const string&str,size_t subpos,size_t sublen);
// 在位置 pos 处插入字符串 str 的从位置 subpos 处开始的 sublen 个字符
string& insert(size_t pos,const char * s);
// 在位置 pos 处插入字符串 s
string& insert(size_t pos,const char * s,size_t n);
// 在位置 pos 处插入字符串 s 的前 n 个字符
string& insert(size_t pos,size_t n,char c);
// 在位置 pos 处插入 n 个字符 c
iterator insert (const_iterator p, size_t n, char c);
// 在 p 处插入 n 个字符 c,并返回插入后迭代器的位置
iterator insert (const_iterator p, char c);
// 在 p 处插入字符 c,并返回插入后迭代器的位置
14、使用 string.erase() 进行元素删除操作
string& erase (size_t pos = 0, size_t len = npos); // 删除从 pos 处开始的 n 个字符
iterator erase (const_iterator p); // 删除 p 处的一个字符,并返回删除后迭代器的位置
iterator erase (const_iterator first, const_iterator last); // 删除从 first 到last 之间的字符,并返回删除后迭代器的位置
15、getline(cin, str);来获取键盘输入到str
16、使用 str.empty() 函数判断字符串是否为空
17、使用 string.swap() 函数交换两个字符串
str.swap(ptr);
18、string.back()获取或修改字符串最后一个字符
string str("abcd");
char b = str.back();
str.back() = 'e';
19、string.front()获取或修改字符串第一个字符
20、string.pop_back()删除字符串最后一个元素
c++ string类
于 2022-11-27 20:59:48 首次发布