当前位置: 首页 > news >正文

c与c++中的字符串

在c++中,string本质上是一个类;

string与char *有些区别:

  • char*是一个指针;
  • string是一个类,类内封装了char*,管理这一个字符串,是一个char*的容器

在使用string类型时,要加上其头文件

string的初始化操作

string str1;

最直接的初始化,一定要记住;

后面几种了解就ok了

第二种:

const char* c="hello world!";
string str2(c);

用char*来存储,存储的是字符串常量,所以某些编译器需要加上const,为保持习惯,建议加上const

第三种:

const char* c="hello world!";
string str2(c);
string str3(str2);

而在输出字符串的时候可以用字符串变量名+[]来输出,好似跟字符指针输出方式一摸一样

所以我感觉:无论是字符指针还是string类名本质是都是字符串首个元素的地址,类似与数组一样,所以可以利用数组的方式进行输出

其实对于字符串中字符的存取(c++中的字符串)还有一个方法就是调用at接口

string的赋值:

第一种方式:最常用基本

string str;
str="hello world!"
cout<<str<<endl;

后面的了解下就欧克了

//第二种
str2=str1;//第三种
string str3;
str3='a';//第四种
string str4;
str4.assign("hello world");
//感觉调用assign这个接口实在不如等号来的方便//第五种
string str5;
str5.assign("hello world",5);//把前五个字符赋值给str5;

其实还有更多赋值方法,不过很鸡肋,大多用不到,就不多介绍了;

string的拼接:重载+=操作符;append接口

重载+=操作符已经封装在这个类内了,我们只需要调用就欧克了

append接口在这里就不介绍了;

string的查找和替换;

查找:find;替换:rfind;

int find(const string &str,int pos=0) const;查找str第一次出现的位置,从pos开始查找

记住这个是从0开始索引,没有找到返回-1;

rfind与find区别:rfind从右往左查找,但返回的值是从左往右计算;

find从左往右查找,返回的值也是从左往右,

其余该查找和替换的函数的不同参数就不介绍了,因为用不到;

string比较;

比较方式是通过ASCII值进行比较;

>返回1,=返回0;<返回-1;

int compare(const string& str)const;

int compare(const char*s)const;

 string的插入和删除;

插入:string& insert(int pos,const char*s);

string& insert(int pos,const string& str);

删除:string& erase(int pos,int n=pos);

这些函数原型都超级简单,手巧几遍就可以轻松学会;

 string子串;

函数原型:string substr(int pos=0,int n=npos)const;返回由pos开始的n个字符组成的字符串

 

第二个参数可以理解为 从pos初开始的n个字符

 

从下标0开始到第三个字符,就是下标0是第一个字符,下标1是第二个字符,下标2是第三个字符,所以只打印abc 

string的两种输入方式:

先介绍两种输出方式:cin/scanf和两种输出方式cout/printf

scanf和printf是格式化输入输出,输入输出效率高,cin和cout是输入输出流,输入输出效率低

输出流之所以慢,是因为是要先把输出的东西放入缓存区再输出;

对于字符:cin的输入忽略空格和回车,scanf("%c",&i)等价于i=getchar(),空格和回车都会被输入;

下面介绍用cin和scanf输入字符串:

string s1;
cin>>s1;

 cin可以直接输入;

const int 10000
string s1;
s1.resize(N);
scanf("%s",&s1[0]);

用scanf输入就比较麻烦了;首先需要先预先指定s1的大小,然后需要在scanf的参数中取首元素地址;但运行速度是比cin快的;
 

http://www.lryc.cn/news/182495.html

相关文章:

  • Android 获取IP地址的Ping值 NetworkPingUtils
  • 数据集笔记:OpenCelliD(手机基站开放数据库)
  • Windows电脑多开器的使用心得分享
  • Android Studio实现简易计算器(带横竖屏,深色浅色模式,更该按钮颜色,selector,style的使用)
  • 虚拟机通过nat模式端口映射实现内网穿透
  • 计算机网络(六):应用层
  • Sublime Text 4 for Mac激活下载
  • 存在负权边的单源最短路径的原理和C++实现
  • 15-自动化测试——理论知识
  • 学信息系统项目管理师第4版系列17_干系人管理
  • 专业PDF编辑阅读工具PDF Expert mac中文特点介绍
  • 处理机调度的概念,层次联系以及七状态模型
  • PS 图层剪贴蒙版使用方法
  • 总结1008
  • 软件工程从理论到实践客观题汇总(头歌第九章至第十七章)
  • ubuntu与win之间共享文件夹
  • flink处理函数--副输出功能
  • Java数据结构————队列
  • 办公网络构建
  • 单层神经网络
  • htb-cozyhosting
  • 网络安全渗透测试工具之skipfish
  • 【Rust】文件系统
  • mysql双主双从读写分离
  • postgresql-物化视图
  • 多层神经网络和激活函数
  • Visual Studio Code键盘快捷键大全
  • 新手学习笔记-----⽂件操作
  • LeetCode 251:展开二维向量
  • 练[BSidesCF 2020]Had a bad day