news 2026/4/25 2:41:06

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/24 0:40:06

玩转AI绘画:Playground v2.5图像生成完全指南

玩转AI绘画&#xff1a;Playground v2.5图像生成完全指南 【免费下载链接】playground-v2.5-1024px-aesthetic 项目地址: https://ai.gitcode.com/hf_mirrors/ai-gitcode/playground-v2.5-1024px-aesthetic 想要轻松创作出令人惊艳的AI艺术作品吗&#xff1f;Playgroun…

作者头像 李华
网站建设 2026/4/22 11:23:03

LangChain从零开始:手把手教你构建大模型应用,解锁AI开发新技能

文章详细介绍了LangChain框架&#xff0c;它是连接大语言模型和现实世界的桥梁。通过组件化设计&#xff0c;LangChain解决了大模型的三大局限性&#xff1a;知识过期、无记忆能力和缺乏工具使用能力。文章从环境搭建开始&#xff0c;逐步介绍了基础工作流、记忆功能、RAG检索增…

作者头像 李华
网站建设 2026/4/23 18:29:32

毕业设计 基于大数据的共享单车数据分析

文章目录0 前言1 项目背景2 项目分析思维导图3 项目分析具体步骤3.1 读取数据3.2 数据分析3.1.1 数据预处理——每日使用量分析3.1.2 连续7天的单日使用分析结论3.1.3 数据预处理——每日不同时间段的使用量分析3.1.4 每日不同时间段使用量分析结论3.1.5 数据预处理——骑行距离…

作者头像 李华
网站建设 2026/4/21 0:54:01

ArcObjects SDK 10.8完整指南:5步快速掌握GIS开发核心技术

ArcObjects SDK 10.8完整指南&#xff1a;5步快速掌握GIS开发核心技术 【免费下载链接】arcobjects-sdk-community-samples This repo contains the source code samples (.Net c#, .Net vb, and C) that demonstrate the usage of the ArcObject SDK. 项目地址: https://gi…

作者头像 李华
网站建设 2026/4/23 11:58:46

终极简化:OpCore-Simplify让Hackintosh配置变得前所未有的简单

终极简化&#xff1a;OpCore-Simplify让Hackintosh配置变得前所未有的简单 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 想要在非苹果硬件上运行mac…

作者头像 李华