C++中string类的常用方法实例总结

 更新时间:2022年03月16日 10:45:00   作者:Goallegoal  
string类是C++提供的抽象数据类型,其支持可变长字符串,下面这篇文章主要给大家总结介绍了关于C++中string类的常用方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

引言

C++中提供了一种新的数据类型——字符串类型(string)。实际上string并不是C++的基本类型,它是在C++标准库中声明的一个字符串类,用这种数据类型可以定义对象,每一个字符串变量都是string类的一个对象。标准库类型string表示可变长的字符序列,使用string类型必须首先包含它的头文件。

作为标准库的一部分,string定义在命名空间std中。

【例】

#include<string>//注意这里没有.h 
using namespace std;

string类的意义有两个:第一个是为了处理char类型的数组,并封装了标准C中的一些字符串处理的函数。而当string类进入了C++标准后,它的第二个意义就是一个容器。

C++ string类常用方法

1、string(const char *s) :将 string 对象初始化为 s 指向的字符串

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(复制构造函数)

string str("abcde");
string str2(str);

4、string() :创建一个默认的 string 对象,长度为 0(默认构造函数)

string str;

5、使用C语言风格字符串处理string对象

string str = "hello!";

6、获取string对象的长度,C语言中使用strlen()来获取字符串长度,C++中使用str.size()或str.length().

string str("hello!");
int len1 = str.size();
int len2 = str.length();

7、将一个 string 对象赋值给另一个 string 对象

string str("hello!");
string str2;
str2 = str;

8、string 对象的拼接

C 语言中使用 strcat、strncat 函数来进行字符串拼接操作,C++中可以采用以下方式:

string str1("hello");
string str2("world");
string str3 = str1 + str2;

9、使用 += 来在一个 string 对象后面附加一个 string 对象、字符以及 C 风格的字符串

string str("hello");
string str2("world");
str += str2;
str += 'a';
str += "abcd";

10、string.append() 函数,在string对象后添加一个string对象或c风格字符串。

string str("hello");
string str2("world");
str.append(str2);
str.append("abcd");

11、string.push_back() 函数来在一个 string 对象后面附加一个字符

string str("hello");
char ch = 'a';
str.push_back(ch);

12、对于string对象的比较,可以直接使用关系运算符。

string str1("abcd");
string str2("abcd");
if(str1 == str2)
    break;

13、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);

14、使用 string.substr() 函数来获取子串

string str("hello");
string str2 = str.substr(3,2)

15、访问 string 字符串的元素

string str("hello");
cout << str[2] << endl;
cout << str.at(2) << endl;

16、使用 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;

17、string.rfind() 与 string.find() 方法类似,只是查找顺序不一样, string.rfind() 是从指定位置 pos (默认为字符串末尾)开始向前查找,直到字符串的首部,并返回第一次查找到匹配项时匹配项首字符的索引。换句话说,就是查找子字符串或字符最后一次出现的位置。

18、string.find_first_of() 方法在字符串中从指定位置开始向后(默认为索引 0 处)查找参数中任何一个字符首次出现的位置

string str("hello world");
int pos = str.find_first_of("abcde");
int pos = str.find_first_of("abcde", 1);  // 第二个参数为位置

19、string.find_last_of() 方法在字符串中查找参数中任何一个字符最后一次出现的位置

20、string.find_first_not_of() 方法在字符串中查找第一个不包含在参数中的字符

21、string.find_last_not_of() 方法在字符串中查找最后一个不包含在参数中的字符

22、使用 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,并返回插入后迭代器的位置

23、使用 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 之间的字符,并返回删除后迭代器的位置

24、使用 getline() 函数来获取 string 输入

string str;
getline(cin, str);

25、使用 string.empty() 函数判断字符串是否为空

26、使用 string.swap() 函数交换两个字符串

string str1 = "hello";
string str2 = "HELLO";
str1.swap(str2);

27、string.back()获取或修改字符串最后一个字符

string str("abcd");
char b = str.back();
str.back() = 'e';

28、string.front()获取或修改字符串第一个字符

29、string.pop_back()删除字符串最后一个元素

总结

到此这篇关于C++中string类的常用方法的文章就介绍到这了,更多相关C++ string类常用方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言FlappyBird飞扬的小鸟实现开发流程

    C语言FlappyBird飞扬的小鸟实现开发流程

    因为在家宅了好多天,随手玩了下自己以前做的一些小游戏,说真的,有几个游戏做的是真的劣质,譬如 flappybird 真的让我难以忍受,于是重做了一波分享给大家
    2022-11-11
  • C++超详细分析单链表的实现与常见接口

    C++超详细分析单链表的实现与常见接口

    链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的,本章带你分析单链表的实现与常见接口
    2022-03-03
  • 基于C语言实现高级通讯录的示例代码

    基于C语言实现高级通讯录的示例代码

    这篇文章主要为大家详细介绍了如何利用C语言实现一个高级通讯录的功能,文中的示例代码讲解详细,具有一定的借鉴价值,需要的小伙伴可以参考一下
    2023-01-01
  • C语言开发实现通讯录管理系统

    C语言开发实现通讯录管理系统

    这篇文章主要为大家详细介绍了C语言开发实现通讯录管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C语言实现打印杨辉三角的方法详细(三种方法)

    C语言实现打印杨辉三角的方法详细(三种方法)

    杨辉三角是中国古代数学的杰出研究成果之一,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合。本文将介绍三种可以实现打印杨辉三角的办法,感兴趣的可以试一试
    2022-01-01
  • C++ Opencv imfill孔洞填充函数的实现思路与代码

    C++ Opencv imfill孔洞填充函数的实现思路与代码

    在Matlab下,使用imfill可以很容易的完成孔洞填充操作,下面这篇文章主要给大家介绍了关于C++ Opencv imfill孔洞填充函数的实现思路与代码,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-09-09
  • 简单谈谈C语言中的= 和==、!=

    简单谈谈C语言中的= 和==、!=

    这篇文章主要给大家介绍了关于C语言中= 和==、!=的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Qt实现定时器的两种方法分享

    Qt实现定时器的两种方法分享

    这篇文章主要为大家详细介绍了Qt中实现定时器的两种不同方法,文中的示例代码讲解详细,对我们了解Qt有一定的帮助,感兴趣的可以跟随小编一起学习一下
    2022-11-11
  • 利用C++单例模式实现高性能配置管理器

    利用C++单例模式实现高性能配置管理器

    这篇文章主要为大家详细介绍了如何利用C++单例模式实现高性能配置管理器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下
    2023-04-04
  • C++超详细讲解友元与内部类

    C++超详细讲解友元与内部类

    朋友们好,这篇播客我们继续C++的初阶学习,现在对我们对C++的友元,内部类知识点做出总结,整理出来一篇博客供我们一起复习和学习,如果文章中有理解不当的地方,还希望朋友们在评论区指出,我们相互学习,共同进步
    2022-06-06

最新评论