C++ string 基本用法
2026/6/11 9:21:51 网站建设 项目流程

前些天发现了一个巨牛的人工智能 学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。

目录

一、C++ string 的创建方式

1、string 的头文件

TIP:

2、常见的创建 string 方式

3、少见的初始化方式

二、C++ string 与C语言 char* 的区别

1、最本质的区别

2、如何访问 string 定义的字符串?

三、C++ string 的基本操作

1、字符串的比较

(1)、字符串如何比较

(2)cout比较实操

(3)调用比较成员函数

2、字符串连接

(1)cout直接法

(2)通过append()函数连接

3、字符/字符串的查找

(1)常用的find函数和rfind函数查找

4、字符串的替换(replace函数)

5、字符串的删除(erase函数)


一、C++ string 的创建方式

1、string 的头文件

#include <iostream>//等价于C语言中的#include<stdio.h> #include <cstring> #include <string.h> //以上两种都是C语言的string头文件 #include <string>//真正的C++头文件

TIP:

在C++中,#include<string>才是真正的C++头文件!

2、常见的创建 string 方式

int main() { string str1 = "str1"; cout << str1 << endl;//调用构造函数 string str2; str2 = "str2"; cout << str2 << endl;//调用拷贝构造函数 string str3 = ("str3"); cout << str3 << endl; return 0; }

输出结果:

3、少见的初始化方式

string str4(4,'x);

用4个字符初始化字符串,输出结果就是xxxx

string str5("iloveyou",1,4);

表示用字符串从下标1开始的4位初始化str5(在C++中,字符串的下标也是从0开始的,跟C语言的数组一样)

所以输出结果就是love

二、C++ string 与C语言 char* 的区别

1、最本质的区别

在于C++ string 定义的字符串没有 ' \0' !

两者不是同类型的,string是字符串类型,而char是字符类型。

char arr[]="iloveyou"; string str5="iloveyou"; cout<<str5.size()<<endl; cout<<str5.length()<<endl;

①C++中的string类对象会在末尾补上'\0',这是因为C++有C语言的历史包袱。因为C语言的字符串以'\0'结尾,所以为了方便在必要时将string字符串转为C类型字符串(利用 c_str 进行转换),所以string类型对象会在末尾补上一个不计入size和capacity的'\0'。

②C++中的string类对象并不会将'\0'作为结束标志,因为string类对象内部维护了一个记录自身长度的成员变量size,在输出string类对象时会根据size的大小决定输出多少个字符,而不是看'\0'的位置决定输出到哪个字符结束。

2、如何访问 string 定义的字符串?

注意string类型可以直接用数组形式【】中括号访问,并且下标也是从0开始的!

首先不能用C语言中的printf(%s)函数访问,因为string类型本质上并不是字符串类型。

若强行访问,输出结果就是乱码!

C++ string为我们提供访问字符串的接口——data(),c_str();

这两个函数将string类型转换为字符串类型,方便我们用printf函数打印。

int main() { string str1 = "str1"; cout << str1 << endl; printf("%s\n", str1); printf("%s\n", str1.data()); printf("%s\n", str1.c_str()); return 0; }

输出结果

三、C++ string 的基本操作

1、字符串的比较

在C++中,字符串比较的规则与C语言相同。

(1)、字符串如何比较

问:“123”和“13”相比,哪个字符串大?

答:“13”更大,因为从左到右比较,字符按照ASCII码值比较,第一个字符都是‘1’,第二个字符‘3’比‘2’大,所以“13”比“123”大。

在C++中,可以cout直接输出判断字符串的比较

(2)cout比较实操

int main() { string first = "123"; string second = "13"; cout << (first < second) << endl; cout << (first != second) << endl; cout << (first > second) << endl; return 0; }

注意事项

  • 因为返回值的问题,所以要用()把比较的式子括起来
  • 返回值是bool类型,若是真,返回1,假就返回0。

(3)调用比较成员函数

cout << first.compare(second) << endl;
返回值为1:first-second>0 ------> first>second

返回值为-1:first-second<0 ------> first<second

返回值为0:first-second=0 ------> first=second

2、字符串连接

(1)cout直接法

int main() { string first = "i love you,"; string second = "i miss you"; cout << first + second << endl; return 0; }

想要把first和second两个字符串进行相加,直接在cout里面使用加法 + !

输出结果就是:i love you,i miss you

(2)通过append()函数连接

因为上述cout直接+,只能将两个完整的字符串进行相加,太笨重,而append()函数更加灵活,可以决定连接第几位开始,且数量可以自己定。

int main() { string first = "i love you,"; string second = "i miss you"; cout << first + second << endl; first.append(second); cout << first << endl; first.append(second, 1, 5); cout << first << endl; first.append(4, '1'); cout << first << endl; first.append("i miss you", 1, 5); cout << first << endl; return 0; }

输出结果:

3、字符/字符串的查找

前言:

string查找类型的函数,如果查找不到,就返回-1。

因此在查找时,一般需要判断返回值是否等于string::nops(值就是-1)

(1)常用的find函数和rfind函数查找


find函数从左往右查找字符串或者字符出现的位置。

rfind函数从右往左查找字符串或者字符出现的位置。

int main() { string first = "i love you,"; string second = "i miss you"; if (first.find('o') != -1) { cout << first.find('o') << endl; } if (first.find("love") != -1) { cout << first.find("love")<< endl; } return 0; }

4、字符串的替换(replace函数)

replace函数的参数一般开始是原始想要替换的下标,之后是替换字符的个数。

int main() { string first = "iloveyou,"; string second = "imissyou"; first.replace(1, 4,second,1,4); cout << first << endl; return 0; }

输出结果就是 imissyou

5、字符串的删除(erase函数)

int main() { string first = "iloveyou,"; string second = "imissyou"; first.erase(0); cout << first << endl; second.erase(1, 4); cout << second << endl; return 0; }

第一种使用方法是删除下标0,及以后的字符(注意是后面的字符全部干掉!)

第二种是用方法是删除下标1,之后的4个字符(自定义删除的个数)

6、字符串的遍历(iterator容器遍历)

iterator容器遍历适用于任何stl库,我们只需要掌握一个方法,其他依葫芦画瓢即可。

iterator使用方法像是指针,但跟指针有区别。有同学会问了,我们直接用 [ ] 访问数组不好吗,为什么还要整个iterator,请注意 [ ] 遍历只适用于内存是连续的情况下,如果是内存不连续(比如图或者树形结构),我们必须要使用iterator进行遍历!

下标+[] 只适用于部分容器,底层物理有一定连续链式结构、树形、哈希结构等只能用迭代器。所以迭代器才是容器访问主流形态!

7、区分const iterator / const_iterator

前者保护的是迭代器本身不能被修改,也就是it,但是这肯定是不可以的,因为我们迭代器要++遍历;

后者保护的是迭代器指向的内容不能修改,也就是*it

8、提取子字符串(substr)

该函数的作用就是提取从pos位置开始,长度为len的子字符串,返回值就是提取的子字符串。

9、输入带有空格的字符串

我们之前使用的cin 、 scanf 都是默认遇到空格或者回车自动停止输入,但如果我们的字符串含有空格要输入,那怎么办呢?

这时候就需要getline出马了!geiline默认遇到空格不会停止输入,只有遇到回车才会停止输入。

一般只有字符串输入空格才会使用getline。

#include<string> #include<iostream> int main() { string s; getline(cin,s); return 0; }

10、字符串与数字的互相转换(to_string & stoi)

to_string 可以将任意类型的数字转换为string类型,非常强大!

同样,stoi(stol)等都是将字符串类型转换为数字类型,其中stoi最常用。

这两个函数记忆方法也简单,to_string函数按照字面意思就是将什么变成string,而stoi其中的s就表示的是string,i 表示int类型的整数!

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询