C++ string 常用函数总结
头文件:#include<string>
[注]:文中关于个数的参数文档中为 size_type
型,更本质是 size_t
型,因为typedef size_t size_type
,而 size_t
在不同系统内实现不同,大概为 unsigned int
型,为简便起见,本文均写为 int
型。另外,string
的许多函数都有各种重载,本文所写的只是较常用的。
赋值
string
类型的变量可以直接赋值:string str = "hello world"; //可以直接赋值
cout << str << endl; //string 不支持 C 语言,因此输出只能使用 cout 不能使用 printf
输出:
hello world
使用
string
的构造函数来实现拷贝的效果:string substr = string(string str, int start, int num);
由此得到的
substr
是截取字符串str
从start
起num
个字符。关于子串还有函数
substr(int start, int num)
,其效果同上。举例如下:
//返回子字符串 substr
string str = "012345678";
string substr = str.substr(1,3);
cout << substr << endl; substr = string(str, 2, 5);
cout << substr << endl;
输出:
123
23456
长度
函数 string.size()
和 string.length()
均可返回本字符串长度,返回值类型为 int(size_t)
。
运算符
字符串连接 +
举例如下:
string str1 = "abc", str2 = "def";
str = str1 + str2;
cout << str << endl;
输出:
abcdef
字典序比较:
> < >= <= != ==
遍历/访问
使用下标
[]
访问同字符数组。
使用迭代器访问
举例如下:
string str = "hello world"; //可以直接赋值
printf("按元素下标访问:%c %c\n", str[0], str[str.size()-1]);
//可以按照元素下标访问 //通过迭代器 iterator 访问 迭代器类似于指针
printf("迭代器访问str:\t");
for(string::iterator it = str.begin(); it != str.end(); ++it)
{
printf("%c ", *it);
}
printf("\n");
printf("str.begin() = #%c#", *str.begin()); //迭代器类似于指针 要加 *
printf("str.end() = #%c#", *str.end());输出:
按元素下标访问:h d
迭代器访问str: h e l l o w o r l d
str.begin() = #h#str.end() = # #
增删改查
插入
string.insert(int pos, string str)
其作用为在字符串
string
第pos
个字符处插入字符串str
。删除
string.erase(int pos, int len)
其作用为从字符串
string
第pos
个字符处删除len
个字符。清空字符串
string.clear()
判断字符串是否为空
string.empty()
举例如下:
string str = "hello world"; //插入
str.insert(0, "Start "); //在开头插入
cout << "开头插入:" << str << endl;
str.insert(str.size(), " End."); //在末尾插入
cout << "末尾插入:" << str << endl;
str.insert(6, "Middle "); //在中间插入
cout << "中间插入:" << str << endl; //删除
str.erase(0,1); //删除 从第 0 位开始的 1 个
cout << "删除第一个元素:" << str << endl;
str.erase(0, 2); //删除 从第 0 位开始的 2 个
cout << "删除前两个元素:" << str << endl;
cout << str.empty() << endl;
str.clear(); //清空
cout << str.empty() << endl;
输出:
开头插入:Start hello world
末尾插入:Start hello world End.
中间插入:Start Middle hello world End.
删除第一个元素:tart Middle hello world End.
删除前两个元素:rt Middle hello world End.
0
1
替换
string.replace(int pos, int len, string temp)
其作用为替换
string
字符串从pos
起len
个字符为 字符串temp
。举例如下:string str = "123456";
string temp = "abc";
str.replace(0, 1, temp);
cout << str << endl;
输出为:
abc23456
查询
string.find()
本函数用于在字符串
string
中寻找字符或字符串,若找到则返回其第一个字符所在下标位置,若没有对应字符或字符串,则返回string.npos
,即-1
。举例如下:string str = "hello world"; int found = str.find("world");
if(found != str.npos) //npos = -1
{
printf("%d\n", found);
} found = str.find('l');
if(found != str.npos)
{
printf("%d\n", found);
} found = str.find('.');
if(found == str.npos)
printf("Not found!\n");
输出为:
6
2
Not found!
C++ string 常用函数总结的更多相关文章
- C++ string 常用函数
C++ String常用函数 一,类型别名 size_type 无符号整型 iterator 迭代器类型 const_iterator 只读迭代器 reverse_iterator 逆序迭代器 con ...
- C#string常用函数总结
补充: 1:在C语言里 char占1个字节 而在C#,Java里char占两个字节 数据库里char 中汉占两个字节 字母数字占一个字 2:string ...
- 【STL】string 常用函数
string类的构造函数: string(const char *s); //用c字符串s初始化 string(int n,char c); //用n个字符c初始化 此外,string类还支持默认构造 ...
- 【转】string常用函数
原文地址:http://hi.baidu.com/baowup/blog/item/3a27465c86d71546faf2c066.html/cmtid/de1ef3f0de7554a0a40f52 ...
- String 类的实现(5)String常用函数
2 #include<iostream> 3 #include<stdio.h> 4 #include<assert.h> 5 #include <iom ...
- stl string常用函数
string类的构造函数: string(const char *s); //用c字符串s初始化 string(int n,char c); //用n个字符c初始化 此外,string类还支持默认构造 ...
- C++中的string常用函数用法
标准c++中string类函数介绍 注意不是CString 之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必 担心内存是否足够.字符串长度等等,而 ...
- c++标准库中的string常用函数总结《转》
标准C++中的string类的用法总结 相信使用过MFC编程的朋友对CString这个类的印象应该非常深刻吧?的确,MFC中的CString类使用起来真的非常的方便好用.但是如果离开了MFC框架,还有 ...
- STL string 常用函数(转)
string类的构造函数: string(const char *s); //用c字符串s初始化 string(int n,char c); //用n个字符c初始化 此外,string类还支持默认构造 ...
- c++中的string常用函数用法总结!
标准c++中string类函数介绍 注意不是CString 之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必 担心内存是否足够.字符串长度等等,而且作 ...
随机推荐
- 【代码分享】用redis+lua实现多个集合取交集并过滤,类似于: select key from set2 where key in (select key from set1) and value>=xxx
redis中的zset结构可以看成一个个包含数值的集合,或者认为是一个关系数据库中用列存储方式存储的一列. 需求 假设我有这样一个数据筛选需求,用SQL表示为: select key from set ...
- 【记录一个问题】macos下lldb调试opencv的一个程序,出现“failed to load objfile for”错误,并且无法调试进入opencv的函数
opencv编译使用了Debug版本,打开了BUILD_WITH_DEBUG_INFO=ON选项. 发现问题后,我又在CMAKE_CXX_FLAGS_DEBUG中设置为 -g -ggdb3,在CMAK ...
- nao机器人使用手册
简单使用和保养 开关机和马达 开机是按一下,后来按一下相当于重启了一次程序,3是播报IP地址,5秒是关机,8秒是强制关机. 电池 3月左右不用需要取下电池.夏天5-8小时,冬天8-10小时充电.活动时 ...
- selenium获取cookies并持久化登陆
selenium获取cookies并持久化登陆 需求背景: 这几天需要写一个接口,用来批量上传数据,最开始考虑的是 UI 自动化,然后选值的时候自动化难以判别,最终选择 接口 自动化. 然后操 ...
- Typora基础快捷键使用流程
Typora简介 Typora是一个所见即所得的Markdown格式文本编辑器,支持windows.macOS和GNU\Linux操作系统,包括对GitHub Flavored Markdown扩展格 ...
- 在海外上传文件到中国AWS S3
s3cmd --access_key= --secret_key=xxxx --region=cn-north-1 --host=s3.cn-north-1.amazonaws.com.cn --ho ...
- 学习JAVAWEB第十五天
今天跟着视频做一个简单的登录界面用到javabean,servlet,数据库等知识,还没做完,明天接着做.
- 第08讲:Flink 窗口、时间和水印
Flink系列文章 第01讲:Flink 的应用场景和架构模型 第02讲:Flink 入门程序 WordCount 和 SQL 实现 第03讲:Flink 的编程模型与其他框架比较 第04讲:Flin ...
- 「NOI十联测」深邃
「NOI十联测」深邃 要使得最大的连通块最小,显然先二分答案. 先固定1结点为根. 对于一个果实,显然是先处理子树中未分配的点,再向外延伸. 每个结点记录一个\(si[]\),表示子树中未分配的点数, ...
- 关于obj.class.getResource()和obj.getClass().getClassLoader().getResource()的路径问题
感谢原文作者:yejg1212 原文链接:https://www.cnblogs.com/yejg1212/p/3270152.html 注:格式内容与原文有轻微不同. Java中取资源时,经常用到C ...