news 2026/4/22 19:22:39

c++的字符串string

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
c++的字符串string

目录

string的概念

string的基本操作

创建

输入

​编辑

获取长度

迭代器

begin()和end()

尾插函数

+=和+运算

尾删pop_back()

insert()插入

find查找

substr()

关系运算

字符串和int 值的转换。


string的概念

string是c++专门创建的字符串类型,为了方便操作字符串。

string中很多的方法。

string的基本操作

首先要包含头文件string.

创建

有初始化的创建,它的末尾不以'\0'为结尾。

#include <iostream> #include<string> using namespace std; int main() { string a="hello world"; //string a("hello world"); cout<<a; return 0; }

string可以直接赋值

#include <iostream> #include<string> using namespace std; int main() { string a; string b("hello world"); a=b; cout<<a; return 0; }

输入

cin输入,不能输入空格

#include <iostream> #include<string> using namespace std; int main() { string a; cin>>a; cout<<a; return 0; }

getline是c++标准函数,读取一行文本存储为字符。

istream&getline(istream& is,string&str);遇到'\n'停止。

#include <iostream> #include<string> using namespace std; int main() { string a; getline(cin,a); cout<<a; return 0; }

istream&getline(istream& is,string&str,char delim);直到遇到delim字符停止

#include <iostream> #include<string> using namespace std; int main() { string a; getline(cin,a,'m');//读到m停止 cout<<a; return 0; }

获取长度

size(),string有很多函数,用 . 使用

#include <iostream> #include<string> using namespace std; int main() { string b; string a="abcd"; string c="abcdefg"; string d="j k l l l"; cout<<a.size()<<endl; cout<<b.size()<<endl; cout<<c.size()<<endl; cout<<d.size()<<endl; return 0; }

string的数据也有下标和正常创建的字符数组一样从0开始。

迭代器

用来遍历容器元素。

iterator类似指针,数组下标。

需要*解引用。

begin()和end()

begin()指向第一个位置,end()指向最后的下一个位置,不存在于字符串。

可以比较大小,加减。

#include <iostream> #include<string> using namespace std; int main() { string a="hello world"; string::iterator it1=a.begin(); string::iterator it2=a.end(); if(it1<it2) cout<<"<"<<endl; else cout<<">"<<endl; return 0; }

可以通过*解引用,输出存储的字符。

#include <iostream> #include<string> using namespace std; int main() { string a="hello world"; string::iterator it1=a.begin(); string::iterator it2=a.end(); cout<<*it1<<endl;//[0] it1++; cout<<*it1<<endl;//[1] it1--; cout<<*it1<<endl;//[0] return 0; }

使用迭代器遍历。

#include <iostream> #include<string> using namespace std; int main() { string a="abcdef"; string::iterator it1=a.begin(); string::iterator it2=a.end(); for (string::iterator i = a.begin(); i != a.end(); ++i) { cout << *i; } cout<<endl; for(auto i=it2-1;i>=it1;--i){ cout<<*i; } return 0; }

还有反向迭代器,reverse_iterator 类型的rbegin(),rend()刚好相反。

尾插函数

a.push_back();在字符串尾部插入字符

#include <iostream> #include<string> using namespace std; int main() { string a="abcdef"; cout<<a<<endl; a.push_back('g'); cout<<a<<endl; return 0; }

+=和+运算

也可以头部拼接。

尾删pop_back()

空的情况下删除会报错。

insert()插入

a.insert(pos , str),在a字符串中的pos位置前插入,str字符串。str可以是string类型的内容,可以是字符串如下图。

a.insert(pos,n,str)插入n个str的字符到pos前。

#include <iostream> #include<string> using namespace std; int main() { string a="abcdef"; cout<<a<<endl; a.insert(3,"6"); cout<<a<<endl; return 0; }

find查找

a.find()返回第一次出现的位置。它的返回值是size_t,相当于下标

a.find(str,位置(默认0))

#include <iostream> #include<string> using namespace std; int main() { string a="abcdef abc def l g k"; string b="de"; string c="l"; size_t t=a.find(b); cout<<t<<endl; cout<<a.find(b,t+1)<<endl; return 0; }

a.find(char*,size_t pos);

可以查找c风格的字符串。

a.find(str,size_t pos ,n)a字符串中查找str前n给字符

也可以找字符。str

找不到会放回-1;无符号整型的-1。2^32-1;

substr()

a.substr(pos,len=npos);pos截取的开始,npos截取的长度。pos默认为0,npos默认到字符串末尾

的长度。

用于截取a字符串pos位置开始n个的字符。

#include <iostream> #include<string> using namespace std; int main() { string a="abcdefghi"; string b=a.substr(3,3); string c=a.substr(3); cout<<b<<endl; cout<<c<<endl; return 0; }

关系运算

==,至少有一个str的字符才可以比较,比较的ascii值对应位置。

#include <iostream> #include<string> using namespace std; int main() { string a="abcdefghi"; string b="abcdefghi"; if(a==b) cout<<"=="<<endl; string c="abcdefgh"; if(a!=c) cout<<"!="<<endl; string d="b"; if(a<d) cout<<"<"<<endl; string e="aa"; if(a>e) cout<<">"<<endl; return 0; }

字符串和int 值的转换。

stoi/stol,stol是int ,stol是long int。

int stoi(str,size_t* idx=0,int base=0)

long stol(str,size_t* idx=0,int base=0)

str是string类型的字符串。

idx是一个指针,从idx位置开始到第一个无法匹配的下标返回

如“123q”返回q的位置

base表示被解析的数字的进制,

2表示被解析的数字当作2进制数字,转化为10进制。

0是自动推到如0x是16,0是8;

#include <iostream> #include<string> using namespace std; int main() { string a="123p"; size_t t=0; int b=stoi(a,&t,10); int c=stoi(a,&t,8); cout<<b<<endl; cout<<c<<endl; return 0; }

stod转化为double,stof转化为float

stod(str,size_t* idx);只有10进制。

stof(str,size_t* idx);

to_string

把数字转换为字符串。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 7:12:46

【深度解析】Nordic nRF54L15:低功耗蓝牙5.3 SoC的破局之道与应用创新

在万物互联的浪潮中&#xff0c;Nordic 推出的nRF54L15凭借蓝牙5.3Thread/Zigbee多协议与Cortex-M33内核的黄金组合&#xff0c;成为物联网&#xff08;IoT&#xff09;与可穿戴设备领域的明星芯片。深圳动能世纪将从技术特性、典型应用场景及开发实践三个维度&#xff0c;剖析…

作者头像 李华
网站建设 2026/4/18 8:21:26

Minecraft世界下载器使用指南

项目介绍 【免费下载链接】minecraft-world-downloader Download Minecraft worlds, extend servers render distance. 1.12.2 - 1.20.1 项目地址: https://gitcode.com/gh_mirrors/mi/minecraft-world-downloader Minecraft世界下载器是一个网络服务工具&#xff0c;它…

作者头像 李华
网站建设 2026/4/17 14:18:24

毕业设计 yolov8叶片病害检测系统(源码+论文)

文章目录0 前言1 项目运行效果2 课题背景2.1 研究背景2.2 研究意义3 设计框架3.1 技术路线3.2 设计框架3.3 核心模块设计1 模型训练模块2 交互系统模块3.4 关键算法实现非极大值抑制(NMS)算法图像处理流程3.5 数据可视化方案3.6 创新点与特色3.7 系统测试方案4 最后0 前言 &am…

作者头像 李华
网站建设 2026/4/21 6:30:19

Golang对接多头借贷行业风险版API:AES加密与结构体映射实战

一、用 Go 构建高并发风控中台 在处理海量信贷申请&#xff08;Loan Origination&#xff09;时&#xff0c;风控系统需要极低的延迟和极高的吞吐量。传统的单一维度查询已不足以应对复杂的欺诈手段。天远API 的“多头借贷行业风险版”通过引入银行/非银、白天/深夜等细分维度&…

作者头像 李华
网站建设 2026/4/16 5:35:07

5个必知技巧:如何构建企业级API流量防护体系

在微服务架构中&#xff0c;API网关作为流量入口&#xff0c;承担着保护后端服务的重要职责。如果你正在为突增流量导致的系统崩溃、恶意攻击影响业务稳定性而烦恼&#xff0c;那么掌握正确的流量控制策略将是你解决问题的关键。本文将带你从实际问题出发&#xff0c;逐步构建完…

作者头像 李华