C++ 序列容器Vector各种方法实现原理(带你从本质理解Vector容器)(下)

简介: C++ 序列容器Vector各种方法实现原理(带你从本质理解Vector容器)(下)

三.vector容器各类方法的实现

由于我们做逆向的人必须理解本质,不然的话如果逆向出来代码,也不知道这是vector的方法,源码贴在这里,源码中有详细的分析,大家自行阅读一边,会有更深的理解。

#include<iostream>
#include<windows.h>
#define success 1
#define error 0
using namespace std;
template <class T_ELE>
class vector{
public:
  vector();
  vector(DWORD dwsize);
  ~vector();
private:
  DWORD m_dwIndex;     //下一个可用索引
  DWORD m_dwIncrement;    //每次增加的容量
  DWORD m_dwLen;       //当前容器的实际大小
  DWORD m_dwInitSize;   //默认初始化的大小
  int *pvector;    //容器指针
public:
  DWORD capacity();        //获取当前容器容量 
  DWORD size();            //当前容器实际元素个数 
  DWORD push_back(T_ELE Elment);   //向容器尾部添加元素(如果需要增容,需要调用增容函数)
  DWORD insert(DWORD dwIndex,T_ELE Element);    //向指定位置添加元素  
  void pop_back();            //删除容器末尾元素  
  DWORD erease(DWORD dwIndex);    //删除指定元素 
  void at(DWORD dwIndex);     //根据索引得到元素 
  void clean();      //清空容器 
private:
  bool expand();
};
template <class T_ELE>
vector<T_ELE>::vector()
:m_dwInitSize(100),m_dwIncrement(5){
  //创建长度为m_dwInitSize个T_ELE对象,在堆中申请内存 
  pvector = new T_ELE[m_dwInitSize];
  //初始化申请的内存
  memset(pvector,0,m_dwInitSize*sizeof(T_ELE));
  //设置其他值
  m_dwLen = 100;
  m_dwIndex = 0;
  cout<<"无参构造函数完成。"<<endl; 
}
template <class T_ELE>
vector<T_ELE>::vector(DWORD dwsize)
:m_dwIncrement(5){
  //创建长度为dwsize个T_ELE对象,在堆中申请内存
  pvector = new T_ELE[dwsize];
  //初始化申请的内存
  memset(pvector,0,dwsize*sizeof(T_ELE));
  //设置其他值
  m_dwLen = dwsize;
  m_dwIndex = 0;
  cout<<"有参构造函数完成。"<<endl; 
}
template <class T_ELE>
vector<T_ELE>::~vector(){
  delete pvector;
  pvector = NULL;
  cout<<"析构函数完成。"<<endl; 
}
template <class T_ELE>
bool vector<T_ELE>::expand(){
  //计算增加后的长度
  int dwTempLen = m_dwLen + m_dwIncrement;
  //申请内存
  T_ELE* ptemp = new T_ELE[dwTempLen];
  //初始化申请的内存
  memset(ptemp,0,dwTempLen*sizeof(T_ELE)); 
  //复制原始内存中的值
  memcpy(ptemp,pvector,m_dwLen*sizeof(T_ELE)); 
  //释放原来空间,更新指针
  delete[] pvector;
  pvector = ptemp; 
  ptemp = NULL;
  //修改其它属性
  m_dwLen = dwTempLen;
  cout<<"增容操作完成。"<<endl;
  return success; 
}
template <class T_ELE>
DWORD vector<T_ELE>::push_back(T_ELE Element){
  //判断是否需要增容 
  if(m_dwIndex>=m_dwLen)expand();
  //将新元素复制到容器最后一个位置
  memcpy(&pvector[m_dwIndex],&Element,sizeof(T_ELE));
  //修改其他属性
  m_dwIndex++;
  m_dwLen++;
  return success;
}
template <class T_ELE>
DWORD vector<T_ELE>::insert(DWORD dwIndex,T_ELE Element){
  //判断是否需要扩容
  if(m_dwIndex >= m_dwLen)expand();
  //判断索引是否合理
  if(dwIndex<0 || dwIndex>m_dwIndex){
    cout<<"索引不合理。"<<endl; 
    return error;
  }
  //将dwIndex之后的元素移动
  //memset(&pvector[dwIndex],pvector,((m_dwIndex-dwIndex)*sizeof(T_ELE)));
  for(int i=m_dwIndex;i>=0;i--){
    memcpy(&pvector[i+1],&pvector[i],sizeof(T_ELE));
  }
  m_dwIndex++;
  //将Element复制到dwIndex
  pvector[dwIndex] = Element;
  //修改属性值
  m_dwLen++;
  cout<<"添加元素成功。"<<endl;
  return success;
}
template <class T_ELE>
void vector<T_ELE>::at(DWORD dwIndex){
  //判断索引是否在合理区间
  if(dwIndex<0 || dwIndex>=m_dwIndex){
    cout<<"索引不合理"<<endl;
    return error;
  }
  //显示dwIndex的值并返回
  cout<<pvector[dwIndex]<<endl;
  return pvector[dwIndex];
}
template <class T_ELE>
void vector<T_ELE>::clean(){
  delete[] pvector;
}
void Test(){
  vector<int>* v1 = new vector<int>(5);
  v1->push_back(0);
  v1->push_back(1);
  v1->push_back(2);
  v1->push_back(4);
  v1->push_back(5);
  v1->push_back(6);
  v1->push_back(7);
  v1->push_back(8);
  v1->push_back(9);
  v1->insert(3,3);
}
int main(){
  Test();
  return 0;
}
相关文章
|
22天前
|
存储 编译器 C语言
【c++丨STL】vector的使用
本文介绍了C++ STL中的`vector`容器,包括其基本概念、主要接口及其使用方法。`vector`是一种动态数组,能够根据需要自动调整大小,提供了丰富的操作接口,如增删查改等。文章详细解释了`vector`的构造函数、赋值运算符、容量接口、迭代器接口、元素访问接口以及一些常用的增删操作函数。最后,还展示了如何使用`vector`创建字符串数组,体现了`vector`在实际编程中的灵活性和实用性。
48 4
|
3天前
|
存储 对象存储 C++
C++ 中 std::array<int, array_size> 与 std::vector<int> 的深入对比
本文深入对比了 C++ 标准库中的 `std::array` 和 `std::vector`,从内存管理、性能、功能特性、使用场景等方面详细分析了两者的差异。`std::array` 适合固定大小的数据和高性能需求,而 `std::vector` 则提供了动态调整大小的灵活性,适用于数据量不确定或需要频繁操作的场景。选择合适的容器可以提高代码的效率和可靠性。
20 0
|
7天前
|
存储 编译器 C语言
【c++丨STL】vector模拟实现
本文深入探讨了 `vector` 的底层实现原理,并尝试模拟实现其结构及常用接口。首先介绍了 `vector` 的底层是动态顺序表,使用三个迭代器(指针)来维护数组,分别为 `start`、`finish` 和 `end_of_storage`。接着详细讲解了如何实现 `vector` 的各种构造函数、析构函数、容量接口、迭代器接口、插入和删除操作等。最后提供了完整的模拟实现代码,帮助读者更好地理解和掌握 `vector` 的实现细节。
18 0
|
2月前
|
存储 C++ 索引
【C++打怪之路Lv9】-- vector
【C++打怪之路Lv9】-- vector
26 1
|
2月前
|
算法 C++ 容器
C++之打造my vector篇(下)
C++之打造my vector篇(下)
35 0
|
11天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
142 77
|
19天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
3天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
18 3
实战~如何组织一个多容器项目docker-compose
|
13天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
54 3
|
19天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
54 7
下一篇
DataWorks