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;
}
相关文章
|
2月前
|
API C++ Windows
Visual C++运行库、.NET Framework和DirectX运行库的作用及常见问题解决方案,涵盖MSVCP140.dll丢失、0xc000007b错误等典型故障的修复方法
本文介绍Visual C++运行库、.NET Framework和DirectX运行库的作用及常见问题解决方案,涵盖MSVCP140.dll丢失、0xc000007b错误等典型故障的修复方法,提供官方下载链接与系统修复工具使用指南。
560 2
|
3月前
|
存储 缓存 监控
用 C++ 红黑树给公司电脑监控软件的日志快速排序的方法
本文介绍基于C++红黑树算法实现公司监控电脑软件的日志高效管理,利用其自平衡特性提升日志排序、检索与动态更新效率,并结合实际场景提出优化方向,增强系统性能与稳定性。
130 4
|
10月前
|
存储 缓存 C++
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
C++ 标准模板库(STL)提供了一组功能强大的容器类,用于存储和操作数据集合。不同的容器具有独特的特性和应用场景,因此选择合适的容器对于程序的性能和代码的可读性至关重要。对于刚接触 C++ 的开发者来说,了解这些容器的基础知识以及它们的特点是迈向高效编程的重要一步。本文将详细介绍 C++ 常用的容器,包括序列容器(`std::vector`、`std::array`、`std::list`、`std::deque`)、关联容器(`std::set`、`std::map`)和无序容器(`std::unordered_set`、`std::unordered_map`),全面解析它们的特点、用法
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
|
存储 搜索推荐 C++
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器2
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器
234 2
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器2
|
存储 C++ 容器
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器1
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器
236 5
|
存储 设计模式 C++
【C++】优先级队列(容器适配器)
本文介绍了C++ STL中的线性容器及其适配器,包括栈、队列和优先队列的设计与实现。详细解析了`deque`的特点和存储结构,以及如何利用`deque`实现栈、队列和优先队列。通过自定义命名空间和类模板,展示了如何模拟实现这些容器适配器,重点讲解了优先队列的内部机制,如堆的构建与维护方法。
178 0
|
存储 编译器 C++
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
236 2
|
编译器 API C语言
超级好用的C++实用库之跨平台实用方法
超级好用的C++实用库之跨平台实用方法
195 6
|
JavaScript 前端开发 Java
通过Gtest访问C++静态、私有、保护变量和方法
通过Gtest访问C++静态、私有、保护变量和方法
346 1
|
设计模式 存储 C++
【C++】C++ STL探索:容器适配器 Stack 与 Queue 的使用及模拟实现(二)
【C++】C++ STL探索:容器适配器 Stack 与 Queue 的使用及模拟实现
137 0

热门文章

最新文章