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

选择网站建设郑州建网站的公司

选择网站建设,郑州建网站的公司,广西远昌建设公司,seo网站推广工具C 浅谈之 STL Vector HELLO,各位博友好,我是阿呆 🙈🙈🙈 这里是 C 浅谈系列,收录在专栏 C 语言中 😜😜😜 本系列阿呆将记录一些 C 语言重要的语法特性 🏃&…

C++ 浅谈之 STL Vector

HELLO,各位博友好,我是阿呆 🙈🙈🙈

这里是 C++ 浅谈系列,收录在专栏 C++ 语言中 😜😜😜

本系列阿呆将记录一些 C++ 语言重要的语法特性 🏃🏃🏃

OK,兄弟们,废话不多直接开冲 🌞🌞🌞


一 🏠 概述

简单介绍

vector 与 array 相似,区别在于:array是静态空间,vector 可动态扩容

vector<typeName> vt(n_elem);    //vector 可用变量初始化, 会自动扩容
array<typeName, n_elem> arr;    //array n_elem 由常量指定, 不会扩容

迭代器

vector 支持随机存取,其迭代器就是普通指针 👊👊👊

template<class T, class Alloc = alloc>
class vector {
public:typedef T value_type;typedef value_type* iterator;   //vector的迭代器是普通指针......
}

数据结构

vecotr 所维护线性连续空间, startfinish 标识连续空间被使用范围,end_of_storage 指向连续空间末尾 👦👦👦

template<class T, class Alloc = alloc>
class vector {
......
protected:iterator start;             //已使用空间的头iterator finish;            //已使用空间的尾iterator end_of_storage;    //可用空间的尾
......
}

vector<int> iv(2,9);
iv.push_back(1);
iv.push_back(2);
iv.push_back(3);
iv.push_back(4);

经如上操作,vector 内存及各成员如下图状态 👇👇👇

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OhXiEfwM-1675942285660)(E:\2022年MD文档\2023 年 MD文档\二月\浅谈系列\C++ 浅谈之 STL Vector 底层实现.assets\1675860481321.png)]

的唯一差别在于空间运用的灵活性:array是静态空间,一旦配置就不能改变;vector是动态空间,随着元素的加入,他的内部机制会自动扩充空间以容纳新的元素。vector的实现技术,关键在于对其大小的控制以及重新配置时的数据移动效率 ✌✌✌


二 🏠 核心

动态扩容

当 vector 大小和容量相等(size==capacity)时,再添加元素,就会扩容

1、弃用现用内存空间,申请更大内存空间

2、将原内存空间数据,按原次序移动到新内存空间

3、旧内存空间释放

4、指向新内存空间


SGI-STL 扩容机制,伪代码如下 👇👇👇

// SGI-STL扩容机制
void reserve(size_type n) {// 当n大于当前vector的容量时才会扩容,小于等于当前容量则忽略本次操作if (capacity() < n) {const size_type old_size = size();// 使用空间配置器开辟n个新空间,并将旧空间元素拷贝到新空间iterator tmp = allocate_and_copy(n, start, finish);// 释放旧空间// a. 先调用析构函数, 将[start, finish)区间总所有的对象析构完整destroy(start, finish);// b. 将空间规划给空间配置器deallocate();// 3. 接收新空间并更新其成员start = tmp;finish = tmp + old_size;end_of_storage = start + n;}
}

小优化 :reserve 预分配空间,避免频繁动态扩容 👨‍🚀👨‍🚀👨‍🚀


Vector 迭代器失效场景

① 当插入一个元素后,end 返回迭代器失效

② 当插入一个元素后,造成动态扩容,first 和 end 返回迭代器失效

③ 删除操作 (erase,pop_back) ,指向删除点和后面元素的迭代器失效 🐌🐌🐌


迭代器失效原因

① vector ,维护连续内存,删除一个元素后,其它数据地址可能会发生变化(erase 会返回下一个有效迭代器)

② map、set、multiset、map、multimap,红黑树或平衡二叉树储存数据,删除了一个元素后,树调整,但其它数据的内存地址无变化,各节点指向关系改变(erase 仅被删元素迭代器失效)

③ list 链表型结构,不连续内存,仅被删元素迭代器失效 🐳 🐳 🐳


不适合插入和删除

元素 3 位置插入 0 ,需将 3 4 5 整体向后搬移一个位置,最差情况下时间复杂度为 O(N)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RxOnh9if-1675942285661)(E:\2022年MD文档\2023 年 MD文档\二月\浅谈系列\C++ 浅谈之 STL Vector 底层实现.assets\1675861548920.png)]

vector不适宜做任意位置插入与删除操作,因为插入和删除时需要搬移大量元素:


如何快速释放内存

reserve 只在传入大小比原有内存大时才触发,而 resize 或 clear 仅对容器元素进行析构,容器本身空间不会释放

① swap

vector().swap(v) 用空 vector 与当前 vector 交换(空 vector 是临时变量,出作用域会自动调用析构) 🐋🐋🐋

② shrink_to_fit

释放未使用内存(C++11),先调 clear 清空元素(整个容器都是未使用了),shrink_to_fit 将未使用内存释放

vector 用 memset 清零

memset :将某块内存内容全部设为指定值, 常为新申请内存初始化,

后果 :破坏 vector 内部结构,可能导致内存泄露 🎅🎅🎅


三 🏠 结语

身处于这个浮躁的社会,却有耐心看到这里,你一定是个很厉害的人吧 👍👍👍

各位博友觉得文章有帮助的话,别忘了点赞 + 关注哦,你们的鼓励就是我最大的动力

博主还会不断更新更优质的内容,加油吧!技术人! 💪💪💪

http://www.hengruixuexiao.com/news/10356.html

相关文章:

  • 建设公司网站新闻宣传管理制度电商平台有哪些
  • 网站类的百度百科怎么做2023最新15件重大新闻
  • 百度竞价广告投放长沙seo关键词
  • 推广网站怎样阻止成都网站建设seo
  • 用什么给网站做测试佛山关键词排名工具
  • 网站空间与服务器的区别优化精灵
  • 北京最新消息今天新增病例seo网站排名优化快速排
  • 邢台提供网站建设公司电话中国国家培训网官网
  • 这几年做网站怎么样拼多多怎么查商品排名
  • 建设定制网站湖南长沙今日疫情
  • 免费php空间国内拼多多seo是什么意思
  • 网站开发要注意安全性网站推广计划书范文500字
  • 上海网站建设网页制作怎么样优化设计七年级下册语文答案
  • wordpress记录用户ip武汉久都seo
  • 日本中古手表网站中国世界排名
  • 神马关键词快速排名软件如何网站seo
  • 南昌网站定制服务百度关键词推广多少钱
  • 做设计的需要网站下载素材吗世界杯积分榜排名
  • 安徽展览展示公司排名天津seo推广
  • 公司变更法人需要多少费用长沙网站seo诊断
  • 好单库如何做网站得物app的网络营销分析论文
  • 视频播放类网站建设费用广东东莞疫情最新情况
  • 免费 网站管理系统网站百度seo关键词优化
  • 微小店网站建设费用百度关键词搜索热度
  • 做护理简历的网站软文推广哪个平台好
  • 乐清网页设计秦皇岛seo优化
  • 苏州模板网站专业设计网络营销推广案例
  • 做谷歌网站买卖友情链接
  • 苏州吴江做网站公司企业网站的在线推广方法有
  • 在线图片编辑免费版seo优化排名百度教程