热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

c++vector模拟实现代码

vector是C++STL中一个非常重要的容器,了解vector的底层实现原理,可以很好的帮助我们更加熟练的使用vector。这篇文章通过实例代码给大家介绍c++vector模拟实现,感兴趣的朋友跟随小编一起看看吧

vector的介绍

1、vector是表示可变大小数组的序列容器。
2、就像数组一样,vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问,和数组一样高效。但是又不像数组,它的大小是可以动态改变的,而且它的大小会被容器自动处理。
3、本质讲,vector使用动态分配数组来存储它的元素。当新元素插入时候,这个数组需要被重新分配大小为了增加存储空间。其做法是,分配一个新的数组,然后将全部元素移到这个数组。就时间而言,这是一个相对代价高的任务,因为每当一个新的元素加入到容器的时候,vector并不会每次都重新分配大小。
4、vector分配空间策略:vector会分配一些额外的空间以适应可能的增长,因为存储空间比实际需要的存储空间更大。不同的库采用不同的策略权衡空间的使用和重新分配。但是无论如何,重新分配都应该是对数增长的间隔大小,以至于在末尾插入一个元素的时候是在常数时间的复杂度完成的。
5、因此,vector占用了更多的存储空间,为了获得管理存储空间的能力,并且以一种有效的方式动态增长。
6、与其它动态序列容器相比(deques, lists and forward_lists), vector在访问元素的时候更加高效,在末尾添加和删除元素相对高效。对于其它不在末尾的删除和插入操作,效率更低。比起lists和forward_lists统一的迭代器和引用更好。

vector是C++ STL中一个非常重要的容器,了解 vector 的底层实现原理,可以很好的帮助我们更加熟练的使用vector。

c++ vector 模拟实现代码:

#include
using namespace std;
namespace bit
{
 template
 class vector
 {
 public:
 typedef T* iterator;
 public:
 T operator[](int i)
 {
  return start[i];
 }
 public:
 vector() :start(nullptr), finish(nullptr), end_of_sorage(nullptr)
 {
 }
 vector(size_t n, const T& value = T()) :start(nullptr), finish(nullptr), end_of_sorage(nullptr)
 {
  reserve(n);//先扩容
  while (n--!=0) //再填充
  {
  push_back(value);
  }
 }
 template //由前后指针来创建
 vector(InPutIterator first, InPutIterator last):start(nullptr), finish(nullptr), end_of_sorage(nullptr)
 {
  reserve(last-first);//先申请空间
  while (first != last)
  {
  push_back(*first);
  first++;
  }
 }
 ~vector()
 {
  delete[]start;
  start = finish = end_of_sorage = nullptr;
 }
 public:
 int size()
 {
  return finish - start;
 }
 int capacity()
 {
  return end_of_sorage - start;
 }
 bool empty()
 {
  return finish == start;
 }
 void swap(vector& v)
 {
  std::swap(start, v.start);
  std::swap(finish, v.finish);
  std::swap(end_of_sorage, v.end_of_sorage);
 }
 void reserve(size_t new_capacity) // 扩容
 {
  if (new_capacity > capacity())
  {
  int old_size = size(); //原来的大小 
  T* newV = new T[new_capacity]; //新申请空间
  if (start)//当原有内容不空时
  {
   for (int i = 0; i  capacity())
  {
  reserve(new_size * 2);
  }
  iterator p = finish;
  finish = start + new_size;//指向新大小
  while (p != finish) //填充value
  {
  *p = value;
  p++;
  }
 }
 public:
 void push_back(const T &c)
 {
  insert(end(), c);
 }
 public:
 typedef T* iterator;
 iterator begin()
 {
  return start;
 }
 iterator end()
 {
  return finish;
 }
 public:
 iterator insert(iterator pos, const T &x) //在pos位置前插入x
 {
  if (size() + 1 >= capacity())
  {
  size_t oldpos = pos - start;
  size_t new_capacity = capacity() ? (capacity() * 2) : 1;
  reserve(new_capacity);
  pos = start + oldpos;
  }
  T* p = finish;
  for (; p != pos; p--)
  {
  *p = *(p - 1);
  }
  *p = x;
  finish++;
  return pos;
 }
 iterator erase(iterator pos) //删除pos位置值
 {
  T* p = pos;
  while (p != finish - 1)
  {
  *p = *(p + 1);
  p++;
  }
  finish--;
  return pos;
 }
 private:
 T* start;//指向最开始
 T* finish;//指向最后一个元素的下一个位置
 T* end_of_sorage;//指向最大容量的下一个位置
 };
}
int main()
{
 int ar[] = { 1,2,3,4,5,6,7,7 };
 bit::vectorv1(ar, ar + 6);
 bit::vectorv2;
 bit::vectorv3(10,'a');
 v1.erase(v1.end()-1);
 v1.insert(v1.begin(), 0);
 v1.swap(v3);
 for (int i = 0; i 

总结

以上所述是小编给大家介绍的c++ vector模拟实现代码,希望对大家有所帮助,也非常感谢大家对网站的支持!


推荐阅读
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了如何找到并终止在8080端口上运行的进程的方法,通过使用终端命令lsof -i :8080可以获取在该端口上运行的所有进程的输出,并使用kill命令终止指定进程的运行。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了C++中省略号类型和参数个数不确定函数参数的使用方法,并提供了一个范例。通过宏定义的方式,可以方便地处理不定参数的情况。文章中给出了具体的代码实现,并对代码进行了解释和说明。这对于需要处理不定参数的情况的程序员来说,是一个很有用的参考资料。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文介绍了MyBioSource转甲状腺素蛋白定量检测ELISA试剂盒的应用方法及特点。ELISA法作为一项新技术在免疫诊断中的应用范围不断扩大,不仅适用于多种病原微生物引起的传染病、非传染病的免疫诊断,也可用于大/小分子抗原的定量检测。ELISA法具有灵敏、特异、简单、快速、稳定及易于自动化操作等特点,是一种早期诊断的良好方法,也可用于血清流行病学调查。MyBioSource转甲状腺素蛋白定量检测ELISA试剂盒使用方法包括对血清和血浆的操作要求。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
author-avatar
水晶玻璃新座
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有