【C++初阶】8. STL初阶 + String类

这篇具有很好参考价值的文章主要介绍了【C++初阶】8. STL初阶 + String类。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【C++初阶】8. STL初阶 + String类

STL初阶

1. 什么是STL

STL(standard template libaray-标准模板库):是C++标准库的重要组成部分,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架

2. STL的版本

原始版本
Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本,本着开源精神,他们声明允许任何人任意运用、拷贝、修改、传播、商业使用这些代码,无需付费。唯一的条件就是也需要向原始版本一样做开源使 用。 HP版本–所有STL实现版本的始祖。
P. J. 版本
由P. J. Plauger开发,继承自HP版本,被Windows VisualC++采用,不能公开或修改,缺陷:可读性比较低, 符号命名比较怪异。
RW版本
由Rouge Wage公司开发,继承自HP版本,被C+ +Builder 采用,不能公开或修改,可读性一般。
SGI版本
由Silicon Graphics Computer Systems,Inc公司开发,继承自HP版 本。被GCC(Linux)采用,可移植性好, 可公开、修改甚至贩卖,从命名风格和编程风格上看,阅读性非常高。在学习STL的过程中,要阅读部分源代码, 主要参考的就是这个版本。

3. STL的六大组件

【C++初阶】8. STL初阶 + String类

String类

1. 为什么学习string类?

1.1 C语言中的字符串

C语言中,字符串是以’\0’结尾的一些字符的集合,为了操作方便,C标准库中提供了一些str系列的库函数,但是这些库函数与字符串是分离开的,不太符合OOP的思想,而且底层空间需要用户自己管理,稍不留神可能还会越界访问。
【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类
但是ASCII码值只适用于英文,对于中文汉字来说无法实现,这时候就出现了Unicode编码(万国码)
【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类

2. 标准库中的string类(string类的用法)

2.1 string类(了解)

string类的文档介绍

  1. 字符串是表示字符序列的类
  2. 标准的字符串类提供了对此类对象的支持,其接口类似于标准字符容器的接口,但添加了专门用于操作单字节字符字符串的设计特性。
  3. string类是使用char(即作为它的字符类型,使用它的默认char_traits和分配器类型(关于模板的更多信 息,请参阅basic_string)。
  4. string类是basic_string模板类的一个实例,它使用char来实例化basic_string模板类,并用char_traits和allocator作为basic_string的默认参数(根于更多的模板信息请参考basic_string)。
  5. 注意,这个类独立于所使用的编码来处理字节:如果用来处理多字节或变长字符(如UTF-8)的序列,这个 类的所有成员(如长度或大小)以及它的迭代器,将仍然按照字节(而不是实际编码的字符)来操作。

总结:

  1. string是表示字符串的字符串类
  2. 该类的接口与常规容器的接口基本相同,再添加了一些专门用来操作string的常规操作。
  3. string在底层实际是:basic_string模板类的别名,typedef basic_string <char, char_traits, allocator> string;
  4. 不能操作多字节或者变长字符的序列。
    在使用string类时,必须包含#include头文件以及using namespace std;

2.2 string类的常用接口说明

1. string类对象的常见构造

【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类

2. string类对象的容量操作

【C++初阶】8. STL初阶 + String类
这边顺便提一嘴,为啥会有两个一样的接口来返回字符串的有效长度呢?
一开始string类中只有length接口,表示字符串的长度 后面出现STL库,为了使其与STL库中接口一致增加了size接口

注意:

  1. size()与length()方法底层实现原理完全相同,引入size()的原因是为了与其他容器的接口保持一致,一般情况下基本都是用size()。
  2. clear()只是将string中有效字符清空,不改变底层空间大小。
  3. resize(size_t n)resize(size_t n, char c)都是将字符串中有效字符个数改变到n个,不同的是当字符个数增多时:resize(n)用0来填充多出的元素空间,resize(size_t n, char c)用字符c来填充多出的 元素空间。注意:resize在改变元素个数时,如果是将元素个数增多,可能会改变底层容量的大小,如果是将元素个数减少,底层空间总大小不变。
  4. reserve(size_t res_arg=0):为string预留空间,不改变有效元素个数,当reserve的参数小于string的底层空间总大小时,reserver不会改变容量大小。

3. string类对象的访问及遍历操作

【C++初阶】8. STL初阶 + String类

2.3 string类的使用形式

string类±读取

【C++初阶】8. STL初阶 + String类

string类遍历

【C++初阶】8. STL初阶 + String类

迭代器的使用形式

【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类

capacity的使用

【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类

扩size(resize) / 扩capacity(recapacity)

【C++初阶】8. STL初阶 + String类
众所周知,扩容是有代价的,尤其是异地扩容,需要释放前空间,再开辟新空间
但是,当我们知道自己所需要的空间大小可不可以一次性开辟好呢?
【C++初阶】8. STL初阶 + String类
【C++初阶】8. STL初阶 + String类

尾插

【C++初阶】8. STL初阶 + String类

任意位置插入/删除string(不推荐)

【C++初阶】8. STL初阶 + String类

赋值assign / 替换replace(不推荐)

【C++初阶】8. STL初阶 + String类

c_str

【C++初阶】8. STL初阶 + String类
主要是为了C++兼容C语言的接口使用

substr

【C++初阶】8. STL初阶 + String类

运算符重载

【C++初阶】8. STL初阶 + String类

3. 习题

3.1 反转字符串

【C++初阶】8. STL初阶 + String类

3.2 字符串相加

【C++初阶】8. STL初阶 + String类
不停的头插,挪动的数据越来越多,时间复杂度O(N2),所以推荐尾插并逆置

3.3 字符串中第一个唯一字符

【C++初阶】8. STL初阶 + String类

3.4 字符串最后单词长度

【C++初阶】8. STL初阶 + String类

4. vs和g++下string结构的说明

注意:下述结构是在32位平台下进行验证,32位平台下指针占4个字节。

vs下string的结构

string总共占28个字节,内部结构稍微复杂一点,先是有一个联合体,联合体用来定义string中字符串的存储空间:
当字符串长度小于16时,使用内部固定的字符数组来存放
当字符串长度大于等于16时,从堆上开辟空间

union _Bxty
{ // storage for small buffer or pointer to larger one
 value_type _Buf[_BUF_SIZE];
 pointer _Ptr;
 char _Alias[_BUF_SIZE]; // to permit aliasing
} _Bx;

这种设计也是有一定道理的,大多数情况下字符串的长度都小于16,那string对象创建好之后,内
部已经有了16个字符数组的固定空间,不需要通过堆创建,效率高。
其次:还有一个size_t字段保存字符串长度,一个size_t字段保存从堆上开辟空间总的容量
最后:还有一个指针做一些其他事情。
故总共占16+4+4+4=28个字节。
【C++初阶】8. STL初阶 + String类
VS下使用的策略其实就是以空间换时间,当长度<16的时候存储在buff当中 当长度>=16时存储在_ptr所指向的空间当中

g++下string的结构

G++下,string是通过写时拷贝实现的,string对象总共占4个字节,内部只包含了一个指针,该指针将来指向一块堆空间,内部包含了如下字段:
空间总大小
字符串有效长度
引用计数

struct _Rep_base
{
 size_type _M_length;
 size_type _M_capacity;
 _Atomic_word _M_refcount;
};

指向堆空间的指针,用来存储字符串
【C++初阶】8. STL初阶 + String类文章来源地址https://www.toymoban.com/news/detail-403129.html

到了这里,关于【C++初阶】8. STL初阶 + String类的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【C++初阶】九、STL容器中的string类(上)

    ========================================================================= 相关代码gitee自取 : C语言学习日记: 加油努力 (gitee.com)  ========================================================================= 接上期 : 【C++初阶】八、初识模板(泛型编程、函数模板、类模板)-CSDN博客  ==============================

    2024年02月04日
    浏览(57)
  • 【C++初阶】STL详解(二)string类的模拟实现

    本专栏内容为:C++学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C++。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C++ 🚚代码仓库:小小unicorn的代码仓库🚚 🌹🌹🌹关注我带你学习编程知识 注:为了防止与标准库当中的string类产生命名冲

    2024年02月05日
    浏览(58)
  • 【C++ STL】string类最全解析(什么是string?string类的常用接口有哪些?)

    目录 一、前言  二、什么是 string ?  💦 string 类的基本概念 💦 string 类与 char * 的区别   💦 string 类的作用  💦 总结  三、string 的常用接口详解  💦string 类对象的默认成员函数 ① 构造函数(初始化) ② 赋值重载(初始化) 💦string 类对象的访问及遍历操作 ① operator[ ]

    2024年04月17日
    浏览(42)
  • 【C++初阶】:string类

    文档里 一般使用 string里重载了一种非常厉害的运算符[ ] 这个运算符本质上是解引用,是数组用来访问数据的运算符。所以我们可以用这个运算符对每个字符进行操作。补充个小知识:string是一个类,类里有许多的成员函数,这些成员函数下面会讲,这里先用一个size,代表字

    2024年02月08日
    浏览(37)
  • C++——模板(初阶) + string

    作者:几冬雪来 时间:2023年5月19日 内容:C++模板 + string讲解 目录 前言: 1.模板:  1.函数模板的隐/显示实例化:  2.类模板: 2.STL:  1.  什么是STL:  2.STL六大组件:  3.string类:  结尾:  在上一篇博客我们结束了动态管理的讲解,并且在最后的时候我们引出了下一个学

    2024年02月05日
    浏览(57)
  • 【c++】STL--string

            最开始我们学习c语言的时候,我们发现刷题或者写代码都是比较麻烦的,如果说用c语言造一辆车,那么我需要用c语言先把轮子造好--各个零件,当我们造好之后再组装。那么c++则是造好了轮子,只需要我们组装就好了。这里的的STL里有各个组件,我只要熟悉的掌握

    2024年02月03日
    浏览(49)
  • [C++]模板初阶与STL简介

    目录 模板初阶与STL简介::                                         1.泛型编程                                         2.函数模板                                         3.类模板                                         4.什么是STL                  

    2023年04月25日
    浏览(34)
  • C++初阶—string类(1)

      目录 1. 为什么要学习string类 1.1 C语言中的字符串 1.2 两个面试题 2. 标准库中的string类 3. string类对象的常见构造  string常见构造类的使用代码演示 4. string类对象的容量操作 string容量相关方法使用代码演示 5. string类对象的访问及遍历操作 string中元素访问及遍历代码演示 6.

    2023年04月08日
    浏览(37)
  • C++ STL string类

    目录 一.为什么学习string类 (1) C语言中的字符串 (2)标准库里面的string类 二. string类的常用接口说明 (1)string类对象的常见构造 (2)string类对象的容量操作 1.size(),length(). 2. capacity() 3.empty()  4.clear()  5.reserve()  6.resize() (3)string类对象的访问及遍历操作  1.operator[ pos

    2024年02月13日
    浏览(35)
  • C++初阶之模板和STL简介

    泛型编程是一种编程范式,旨在实现可重用、通用和高度抽象的代码。它允许程序员编写与数据类型无关的代码,以便在不同的数据类型上进行操作,而无需为每种数据类型重复编写代码。 在传统的编程中,通常需要为每种数据类型编写特定的代码。例如,如果要实现一个排

    2024年02月16日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包