STL之string类型

1.String概念

string是STL的字符串类型,通常用来表示字符串。而在使用string之前,字符串通常是用char*表示的。
string和char*的区别:

  • string是一个类, char*是一个指向字符的指针。
    string封装了char*,管理这个字符串,是一个char*型的容器。也就是说string是一个容器,里面元素的数据类型是char*。

  • string不用考虑内存释放和越界。
    string管理char*所分配的内存。每一次string的复制,取值都由string类负责维护,不用担心复制越界和取值越界等。

  • string提供了一系列的字符串操作函数 查找find,拷贝copy,删除erase,替换replace,插入insert

2.初始化–构造函数

  • 默认构造函数 : string();//构造一个空的字符串string s1
  • 拷贝构造函数: string(const string &str);//构造一个与str一样的string。如string s1(s2)
  • 带参数的构造函数 :
    string(const char *s); //用字符串s初始化
    string(int n,char c); //用n个字符c初始化
#include <iostream>
#include <string>
#include <algorithm>using namespace std;
// string的构造
void func1()
{string s1 = "hello";string s2("world");string s3 = s2; // 拷贝构造string s4(s1);  // 拷贝构造string s5(10,'a');  // 字符串长度为10,每个值都是'a'cout << s1 << endl;cout << s2 << endl;cout << s3 << endl;cout << s4 << endl;cout << s5 << endl;
}int main()
{func1();system("pause");return 0;
}

3.存取字符

string类的字符操作:

const char &operator[] (int n) const;
const char &at(int n) const;
char &operator[] (int n);
char &at(int n);

operator[]和at()均返回当前字符串中第n个字符,但二者是有区别的。
主要区别在于at()在越界时会抛出异常,[]在刚好越界时会返回(char)0,再继续越界时,编译器直接出错。如果你的程序希望可以通过try,catch捕获异常,建议采用at()。

string的长度

int length() const;   //返回当前字符串的长度。长度不包括字符串结尾的'\0'。
bool empty() const;     //当前字符串是否为空

string遍历
string的遍历可以分为数组方式和使用迭代器两种方式。

// 遍历
void func2()
{string str = "hello world";// 1、用数组下标的方式for (unsigned int i = 0; i < str.length(); i++){cout << str[i] << " ";}cout << endl;// 2、通过迭代器string::iterator it;for (it = str.begin(); it != str.end(); it++){cout << *it << " ";}cout << endl;// at(index) 函数for (unsigned int i = 0; i < str.length(); i++){cout << str.at(i) << " ";}cout << endl;// [] 和 at 区别:当数组越界的时候,[] 会直接让程序崩掉、at会抛出异常{try{for (unsigned int i = 0; i < str.length()+10; i++){//  cout << str[i] << " ";cout << str.at(i) << " ";}cout << endl;}catch (exception &e){printf ("捕获一个异常: %s\n", e.what());}}}

string赋值操作

string &operator=(const string &s);//把字符串s赋给当前的字符串
string &assign(const char *s); //把字符串s赋给当前的字符串
string &assign(const char *s, int n); //把字符串s的前n个字符赋给当前的字符串
string &assign(const string &s);  //把字符串s赋给当前字符串
string &assign(int n,char c);  //用n个字符c赋给当前字符串
string &assign(const string &s,int start, int n);  //把字符串s中从start开始的n个字符赋给当前字符串

4.和char*类型的转换

从string转换到char*的成员函数主要是:
const char *c_str() const; //返回一个以’\0’结尾的字符串的首地址

把string拷贝到char*指向的内存空间的成员函数是:
int copy(char *s, int n, int pos=0) const;
把当前串中以pos开始的n个字符拷贝到以s为起始位置的字符数组中,返回实际拷贝的数目。

注意要保证s所指向的空间足够大以容纳当前字符串,不然会越界。

/ string  --->  char*
// char *  --->  string 
void func4()
{string str = "hello world";// 返回 string 字符串的 char *类型指针const char *ps = str.c_str();printf("str = %s\n", ps);
}

5.比较操作

int compare(const string &s) const;  //与字符串s比较
int compare(const char *s) const;   //与字符串s比较

compare函数在>时返回 1,<时返回 -1,==时返回 0。比较区分大小写,比较时参考字典顺序,排越前面的越小。大写的A比小写的a小。

6.string的连接和复制

// 连接和复制
void func3()
{string str1 = "hello";string str2 = " world";// 两个字符串的连接string s3 = "1234 " + str1 + str2 + " abc";str1 += " 1234";cout << str1 << endl;cout << s3 << endl;// 复制string s4;s4  = str1; // 重载 = 运算符cout << s4 << endl;// 对数组进行 复制  string  ---> char []char c[100] = {0};str1.copy(c, 5);cout << c << endl;
}

7.查找和替换

// 查找和替换
void func5()
{string str = "123 hello 456 hello 789 hello abc hello";// 查找子串// 找到的是第一个相匹配的字符串的下标int index = str.find("ahello", 0);if (index != string::npos)cout << index << endl;index = str.find("hello", 0);while (index != string::npos){cout << index << endl;index = str.find("hello", index+1);}// 替换string str2 = "123 abc asdasdsa";str2.replace(1, 2, "xxx");cout << str2 << endl;index = str.find("hello", 0);while (index != string::npos){str.replace(index, 5, "HELLO");index = str.find("hello", index+1);}cout << str << endl;
}

8.删除和插入

// 删除
void func6()
{string str = "123 hello 456 hello 789 hello abc hello";// 通过迭代器删除某一个元素str.erase(str.begin()+ 8);cout << str << endl;// 1、str.findint index = str.find('b', 0);if (index != string::npos)str.erase(str.begin()+index);cout << str << endl;// 2、通过 查找算法 去 某个字符,算法 操作都是迭代器 // 和 str 内置的 str.find 区分开  find 是算法库提供的函数 ,返回的是一个迭代器,指向找到的元素string::iterator it = find(str.begin(), str.end(), '9');if (it != str.end())str.erase(it);cout << str << endl;str.erase(4, 5);  // 从下标为 4 的位置开始,删除5个元素,如果没有第二个参数,删除4之后所有的元素cout << str << endl;// 区间删除string str1 = "123 hello 456 hello 789 hello abc hello";// 删除方式  是 左闭 又开的    [begin, end)str1.erase(str1.begin(), str1.begin()+4);str1.erase(str1.begin(), str1.end());cout << str1 << endl;
}

9.算法相关

使用transform函数将string里面的字符进行大小写的转换(具体的STL的算法另作介绍):

#define _CRT_SECURE_NO_WARNINGS#include <iostream>
#include <iterator>
#include <vector>
#include <algorithm>
#include <string>using namespace std;void play()
{string s1 = "AAAbbb";transform(s1.begin(), s1.end(), s1.begin(), toupper);cout << "s1" << s1 << endl;string s2 = "AAAbbb";transform(s2.begin(), s2.end(), s2.begin(), tolower);cout << "s2:" << s2 << endl;
}int main()
{ play();system("pause");return 1;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/448348.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解决maven打包报错:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:2.3.2

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 一、报错经历&#xff1a; 今天使用eclipse通过maven install打war包的时候&#xff0c;出现了下图所示的错误 二、问题分析&#xff1a…

离合器

离合器的定义 汽车离合器位于发动机和变速箱之间的飞轮壳内&#xff0c;用螺钉将离合器总成固定在飞轮的后平面上&#xff0c;离合器的输出轴就是变速箱的输入轴。在汽车行驶过程中&#xff0c;驾驶员可根据需要踩下或松开离合器踏板&#xff0c;使发动机与变速箱暂时分离和…

Python 删除满足条件的某些行

数据&#xff1a; data 字段&#xff1a;col 要删除的内容是 col False 的行 # 方案一 data1 data[~data[col] False] # ~ 取反# 方案二 保留 data[已采] ! False ind data[col] ! False data2 data.loc[ind,]# 方案三 去掉 data[已采] True ind2 data[col] False…

STL之Vector

1.简介 vector是将元素置于一个动态数组中加以管理的容器。可以随机存取元素&#xff08;支持索引值直接存取&#xff0c;用[]操作符或at()方法&#xff0c;还支持迭代器方式存取&#xff09;。   vector尾部添加或移除元素非常快速。但是在中部或头部插入元素或移除元素比…

解决 : Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 1. 执行 maven install 命令报错如题&#xff1a; Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:comp…

制动踏板

什么是制动踏板 制动踏板就是限制动力的踏板&#xff0c;即脚刹(行车制动器)的踏板&#xff0c;是长时间摩擦导致刹车片过热软化的原因。制动踏板的作用 其主要作用是刹车减速或停车。 制动踏板的工作原理 在机器的高速轴上固定一个轮或盘&#xff0c;在机座上安装…

实现一个用户取过的数据不被其他用户取到

实现一个用户取过的数据不被其他用户取到: 问题&#xff1a; 在用ADO访问数据库时&#xff0c;从一个表中取一定的记录&#xff08;比如20行&#xff09;&#xff0c;取出后在程序中使用&#xff0c;使用完后删除掉记录&#xff08;不用更新或删除记录&#xff09;。在多用户操…

Docker 镜像 重命名

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 1. 镜像改名命令格式&#xff1a; # 命令格式&#xff1a;docker tag 镜像id 仓库&#xff1a;标签或&#xff1a;docker tag 旧镜…

STL之deque和其他容器

deque简介 deque是“double-ended queue”的缩写&#xff0c;和vector一样都是STL的容器&#xff0c;deque是双端数组&#xff0c;而vector是单端的。 deque在接口上和vector非常相似&#xff0c;在许多操作的地方可以直接替换。 deque可以随机存取元素&#xff08;支持索引…

Java蓝桥杯02——第二题集锦:生日蜡烛、星期一、方格计数、猴子分香蕉

第二题 生日蜡烛(结果填空) 某君从某年开始每年都举办一次生日party&#xff0c;并且每次都要吹熄与年龄相同根数的蜡烛。 现在算起来&#xff0c;他一共吹熄了236根蜡烛。 请问&#xff0c;他从多少岁开始过生日party的&#xff1f; 请填写他开始过生日party的年龄数。 注意&a…

夜考

夜考内容 夜考主要考察夜间汽车灯的使用。上车前准备 1、向考官报告 2、绕车一周观察车辆状况 3、观察车前道路上是否有障碍 4、观察后方是否有来车 注意事项 1、发动车辆时&#xff0c;记得打开车灯; 2、会车时&#xff0c;距来车150米左右&#xff0c;使用近光灯;…

解决:Error response from daemon: Get https://index.docker.io/v1/search?q=openjdkn=25: dial tcp: looku

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 1. 我只是想查一个 mysql 镜像。执行命令&#xff1a; docker search mysql 。报错如下&#xff1a; Error response from daemon…

STL之set

set简介 set是一个集合容器&#xff0c;其中所包含的元素是唯一的&#xff0c;集合中的元素按一定的顺序排列。元素插入过程是按排序规则插入&#xff0c;所以不能指定插入位置。 set采用红黑树变体的数据结构实现&#xff0c;红黑树属于平衡二叉树。在插入操作和删除操作上比…

大三了,计算机专业学生的困惑。 [转]

我现在已经大三了觉得进大学里职业或是学习必须要有一个很好的规划要不然真的会浪费很多时间在一些无谓的事情上自己需要有个明确的目标&#xff0c;否则真的会错失方向我知道不要太浮躁&#xff0c;很容易被一些表面上的东西诱惑。有师长建议时说&#xff1a;我今年毕业&#…

夜间行驶

夜间行驶的特点 特点是视线差&#xff0c;而且驾驶者容易被对面来车大灯晃的眩目&#xff0c;眼前一片漆黑&#xff0c;而造成操作失当。注意事项 1、会车时应注意减速&#xff0c;观察前方与两侧情况&#xff0c;关闭远光灯; 2、进出主路先看车灯; 3、掌握安全车速&…

解决: /bin/sh: 1: java: not found

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 1. 情况描述&#xff1a; 我自己写 dockerfile , buid 了一个镜像&#xff0c;接下来就想后台方式 run 一个容器&#xff0c; docke…

STL之map和multimap容器

1.简介 map是标准的关联式容器&#xff0c;一个map是一个键值对序列&#xff0c;即(key,value)对。它提供基于key的快速检索能力。map中key值是唯一的。集合中的元素按一定的顺序排列。元素插入过程是按排序规则插入&#xff0c;所以不能指定插入位置。map的具体实现采用红黑树…

移动APP接口安全性设计

移动APP接口是怎么保证安全性的&#xff0c;可以采用https&#xff0c;或者是非对称加密。 接口加密的目的是防止被别人用抓包工具&#xff0c;抓包后篡改数据。 关于加密算法常见的有对称加密&#xff08;DES&#xff09;和非对称加密&#xff08;RSA&#xff09; 对称加密&am…

掉头

掉头技巧 掉头前打左灯、减速(至五公里左右)甚至停下&#xff0c;注意观察路况&#xff0c;同时密切注意来往车辆情况(尤其是远一点但车速快的)&#xff0c;必要时停车等待。操作方法 1、在较宽广的道路上&#xff0c;应尽量地应用大遇回一次顺车掉头。如在有交通指挥人…

深入理解 Git 的实现原理

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 我一直很佩服能静心细读各种官方文档的人&#xff0c;此文转自&#xff1a;https://www.cnblogs.com/mamingqian/p/9711975.html 原作者…