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;
}
相关文章
|
3月前
|
移动开发 前端开发 HTML5
Twaver-HTML5基础学习(20)数据容器(3)_数据的批量加载(节省性能方法)
本文介绍了Twaver HTML5中数据的批量加载方法,通过使用`box.startBatch()`可以在大量数据加载时提高性能。文章通过示例代码展示了如何在React组件中使用批量加载功能,以减少界面重绘次数并提升效率。
59 2
Twaver-HTML5基础学习(20)数据容器(3)_数据的批量加载(节省性能方法)
|
19天前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
29 5
|
19天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
47 3
|
4月前
|
存储 C++ 容器
如何将没有复制或移动构造函数的对象放入vector容器
如何将没有复制或移动构造函数的对象放入vector容器
45 0
|
2月前
|
Kubernetes 监控 Cloud Native
|
3月前
|
编译器 API C语言
超级好用的C++实用库之跨平台实用方法
超级好用的C++实用库之跨平台实用方法
44 6
|
2月前
|
前端开发 Docker 容器
主机host服务器和Docker容器之间的文件互传方法汇总
Docker 成为前端工具,可实现跨设备兼容。本文介绍主机与 Docker 容器/镜像间文件传输的三种方法:1. 构建镜像时使用 `COPY` 或 `ADD` 指令;2. 启动容器时使用 `-v` 挂载卷;3. 运行时使用 `docker cp` 命令。每种方法适用于不同场景,如静态文件打包、开发时文件同步及临时文件传输。注意权限问题、容器停止后的文件传输及性能影响。
432 0
|
3月前
|
XML Java 开发者
经典面试---spring IOC容器的核心实现原理
作为一名拥有十年研发经验的工程师,对Spring框架尤其是其IOC(Inversion of Control,控制反转)容器的核心实现原理有着深入的理解。
149 3
|
3月前
|
JavaScript 前端开发 Java
通过Gtest访问C++静态、私有、保护变量和方法
通过Gtest访问C++静态、私有、保护变量和方法
96 0
|
4月前
|
传感器 定位技术 C++
基于C++的GDAL用空白栅格填充长时间序列遥感影像中的缺失图像
然后,定义需要处理的遥感影像路径列表,和识别数据缺失的逻辑。这里我们简化处理,假设已经知道哪一幅图像是缺失的,因此直接跳过识别步骤。
63 1