C++之string类详解

一、string类简介

字符串是存储在内存中的连续字节中的一系列字符,C++处理字符串有两种方式,一种来自 C 语言,常被称为 C-风格字符串,另一种是基于 string 类库的字符串处理方式。
C++ 中提供了专门的头文件 string(注意不是 string.h,这个是 C 风格字符串相关函数的头文件),来支持 string 类型。string 类定义隐藏了字符串的数组性质,让我们可以像处理普通变量那样处理字符串。string 对象和字符数组之间的主要区别是:可以将 string 对象声明为简单变量,而不是数组。

1.1、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对象,拷贝构造

string str1("hello!");
string str2(str1);

4)string():默认构造函数,创建一个空的string对象

string str;

string 类的设计允许程序自动处理 string 的大小,因此,上述代码创建了一个长度为 0 的string 对象,但是向 str 中写入数据时,程序会自动调整 str 的长度。因此,与使用数组相比,使用 string 对象更方便,也更安全。

1.2 、用C语言风格初始化string对象

string str = "hello!"; //先调用string(const char* s)生成一个匿名对象,再用这个匿名对象去拷贝初始化str

二、获取string对象的长度

在 C 语言中,使用 strlen 函数获取字符串的长度。在 C++ 中,可以使用 string.size() 函数或 string.length() 函数来获得 string 对象的长度。在 C++ 标准库中,两者的源代码如下:

size_type   __CLR_OR_THIS_CALL   length()   const   
{ //   return   length   of   sequence   
return   (_Mysize);   
}   
   
size_type   __CLR_OR_THIS_CALL   size()   const   
{ //   return   length   of   sequence   
return   (_Mysize);   
}

可见,这两个方法是完全一样的,并没有区别。length() 方法是 C 语言习惯保留的,size() 方法则是为了兼容 STL 容器而引入的。

string str("Hello,World!");
int strLen1 = str.length();
int strLen2 = str.size();

三、string对象的拼接和附加

在 C 语言中,使用 strcat、strncat 函数来进行字符串拼接操作。在 C++ 中也有多种方法来实现字符串拼接和附加操作:

3.1、使用+操作符拼接两个字符串

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

3.2、使用+=操作符在字符串后添加内容

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

string str1("hello ");
string str2("world!\n");//这里’\n’也计入长度

str1 += str2;//添加string对象
str1 += "nice job\n";//添加C风格字符串
str1 += 'a';//添加

3.3、使用string.append()函数

可以使用 string.append() 函数来在一个 string 对象后面附加一个 string 对象或 C 风格的字符串:

string str1 = "hello,world!";
string str2 = "HELLO,WORLD!";
    
str1.append(str2);
str1.append("C string");

3.4、使用string.push_back()函数

可以使用 string.push_back() 函数来在一个 string 对象后面附加一个字符:

string str("Hello");
str.push_back('a');

四、string对象的插入和删除

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

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

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

可以使用 string.substr() 函数来获取子串,string.substr() 函数的定义如下:

string substr(size_t pos = 0,size_t len = npos)const;

其中,pos 是子字符串的起始位置(索引,第一个字符的索引为 0),len 是子串的长度。这个函数的功能是:复制一个 string 对象中从 pos 处开始的 len 个字符到 string 对象 substr 中去,并返回 substr。

string str("Hello,World!");
string subStr = str.substr(3,5);
cout << subStr << endl;

这段代码的输出结果为:“lo,Wo”。

六、string对象的比较

在 C 语言中,使用 strcmp、strncmp 函数来进行字符串的比较。在 C++ 中,由于将 string 对象声明为了简单变量,故而对字符串的比较操作十分简单了,直接使用关系运算符(==、!=、<、<=、>、>=)即可:

int main() 
{
    string str1("hello");
    string str2("hello");

    if (str1 == str2)
        cout << "str1 = str2" << endl;
    else if (str1 < str2)
        cout << "str1 < str2" << endl;
    else
        cout << "str1 > str2" << endl;

    return 0;
}

当然,也可以使用类似 strcmp 的函数来进行 string 对象的比较,string 类提供的是 string.compare() 方法,函数原型如下:

int compare(const string&str) const;

int compare(size_t pos,size_t len,const string&str)const;    // 参数 pos 为比较字符串中第一个字符的位置,len 为比较字符串的长度

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;

七、string 对象的查找操作

7.1、使用 string.find() 方法查找字符

find 方法的函数原型如下:
1)从字符串的 pos 位置开始(若不指定 pos 的值,则默认从索引 0 处开始),查找子字符串 str。如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回 string::npos:

size_type find (const string& str, size_type pos = 0) const;

2)从字符串的 pos 位置开始(若不指定 pos 的值,则默认从索引 0 处开始),查找子字符串 s。如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回 string::npos:

size_type find (const char *s, size_type pos = 0) const;

3)从字符串的 pos 位置开始(若不指定 pos 的值,则默认从索引 0 处开始),查找 s 的前 n 个字符组成的子字符串。如果找到,则返回该子字符串首次出现时其首字符的索引;否则,返回 string::npos:

size_type find (const char *s, size_type pos, size_type n);

4)从字符串的 pos 位置开始(若不指定 pos 的值,则默认从索引 0 处开始),查找字符 ch 。如果找到,则返回该字符首次出现的位置;否则,返回 string::npos:

size_type find (char ch, size_type pos = 0) const;

7.2、string.rfind()

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

7.3、string.find_first_of()

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

7.4、string.find_last_of()

string.find_last_of() 方法在字符串中查找参数中任何一个字符最后一次出现的位置(也就是从指定位置开始往前查找,第一个出现的位置)。

7.5、string.find_first_not_of()

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

7.6、string.find_last_not_of()

string.find_last_not_of() 方法在字符串中查找最后一个不包含在参数中的字符(从指定位置开始往前查找,第一个不包含在参数中的字符)。

八、string 对象的一些其他操作

8.1、访问 string 字符串的元素

可以像 C 语言中一样,将 string 对象当做一个数组,然后使用数组下标的方式来访问字符串中的元素;也可以使用 string.at(index) 的方式来访问元素(索引号从 0 开始):

string str("Hello,World!");
cout << str[1] << endl;      // 使用数组下标的方式访问 string 字符串的元素
cout << str.at(1) << endl;     // 使用 at 索引访问 string 字符串的元素

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

string str;

getline(cin,str);    // 从输入流中读取一行数据到 str

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

string str;

if(str.empty()){
    cout << "字符串为空" << endl;  
}

8.4、使用 swap 函数交换两个字符串

int main() 
{
    string str1 = "hello,world!";
    string str2 = "HELLO,WORLD!";

    str1.swap(str2);

    cout << str1 << endl;
    cout << str2 << endl;

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值