news 2026/6/10 17:55:59

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/6/9 19:21:46

HeidiSql 数据库可视化工具 v12.14,支持访问 MySQL、MariaDB 和 SQL Server

免费开源的轻量级数据库客户端软件&#xff0c;拥有图形化界面&#xff0c;支持访问 MySQL、MariaDB 和 SQL Server。允许浏览数据库&#xff0c;管理表&#xff0c;浏览和编辑记录&#xff0c;管理用户权限等等。 HeidiSQL官方版是一款开源的数据库管理软件。 HeidiSQL官方版…

作者头像 李华
网站建设 2026/6/10 15:37:55

n型TOPCon电池中通过氘化/氢化混合策略提升钝化性能

在晶体硅太阳能电池领域&#xff0c;隧穿氧化层钝化接触&#xff08;TOPCon&#xff09;技术是突破效率瓶颈的关键方向&#xff0c;其钝化性能直接决定电池效率。目前&#xff0c;TOPCon结构的制备严重依赖氢化工艺来中和缺陷&#xff0c;但传统方法面临钝化效果提升有限、工艺…

作者头像 李华
网站建设 2026/6/10 16:21:42

霞鹜文楷:零成本打造专业中文排版的终极指南

霞鹜文楷&#xff1a;零成本打造专业中文排版的终极指南 【免费下载链接】LxgwWenKai LxgwWenKai: 这是一个开源的中文字体项目&#xff0c;提供了多种版本的字体文件&#xff0c;适用于不同的使用场景&#xff0c;包括屏幕阅读、轻便版、GB规范字形和TC旧字形版。 项目地址:…

作者头像 李华
网站建设 2026/6/10 15:38:23

java竞赛快速输入模版

1 BufferedReaderBufferedReader 在处理大量数据的时候比Scanner高效&#xff0c;下面看基本写法&#xff1a;import java.util.*; import java.io.*; public class Main{public static void main(String[] args){BufferedReader bf new BufferedReader(new InputStreamReader…

作者头像 李华
网站建设 2026/6/10 15:21:15

iOS 17隐私合规终极指南:Reachability快速配置教程

iOS 17隐私合规终极指南&#xff1a;Reachability快速配置教程 【免费下载链接】Reachability ARC and GCD Compatible Reachability Class for iOS and MacOS. Drop in replacement for Apple Reachability 项目地址: https://gitcode.com/gh_mirrors/re/Reachability …

作者头像 李华