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;
}
相关文章
|
4天前
|
存储 C语言 C++
【C++】vector的使用上
**C++ STL的vector简介与用法:** Vector是动态顺序数组,提供高效下标访问,支持动态增长。与数组类似但可自动调整大小。常用构造函数包括默认、填充、迭代器范围和拷贝构造。析构函数自动释放内存。赋值运算符执行深拷贝。迭代器接口包括`begin()`和`end()`(反向对应`rbegin()`和`rend()`),C++11增加了const版本以支持只读访问。示例代码展示了不同构造函数和迭代器的使用。
|
4天前
|
算法 数据处理 C++
|
4天前
|
编译器 C++
【C++】vector的使用下
**C++ 中的 `std::vector` 概要:** - **元素获取:** 支持 `operator[]`(越界时不检
|
4天前
|
编译器 C++
【C++】string类的使用④(字符串操作String operations )
这篇博客探讨了C++ STL中`std::string`的几个关键操作,如`c_str()`和`data()`,它们分别返回指向字符串的const char*指针,前者保证以&#39;\0&#39;结尾,后者不保证。`get_allocator()`返回内存分配器,通常不直接使用。`copy()`函数用于将字符串部分复制到字符数组,不添加&#39;\0&#39;。`find()`和`rfind()`用于向前和向后搜索子串或字符。`npos`是string类中的一个常量,表示找不到匹配项时的返回值。博客通过实例展示了这些函数的用法。
|
4天前
|
存储 C++
【C++】string类的使用③(非成员函数重载Non-member function overloads)
这篇文章探讨了C++中`std::string`的`replace`和`swap`函数以及非成员函数重载。`replace`提供了多种方式替换字符串中的部分内容,包括使用字符串、子串、字符、字符数组和填充字符。`swap`函数用于交换两个`string`对象的内容,成员函数版本效率更高。非成员函数重载包括`operator+`实现字符串连接,关系运算符(如`==`, `&lt;`等)用于比较字符串,以及`swap`非成员函数。此外,还介绍了`getline`函数,用于按指定分隔符从输入流中读取字符串。文章强调了非成员函数在特定情况下的作用,并给出了多个示例代码。
|
4天前
|
C++
【C++】string类的使用④(常量成员Member constants)
C++ `std::string` 的 `find_first_of`, `find_last_of`, `find_first_not_of`, `find_last_not_of` 函数分别用于从不同方向查找目标字符或子串。它们都返回匹配位置,未找到则返回 `npos`。`substr` 用于提取子字符串,`compare` 则提供更灵活的字符串比较。`npos` 是一个表示最大值的常量,用于标记未找到匹配的情况。示例代码展示了这些函数的实际应用,如替换元音、分割路径、查找非字母字符等。
|
4天前
|
C++
C++】string类的使用③(修改器Modifiers)
这篇博客探讨了C++ STL中`string`类的修改器和非成员函数重载。文章介绍了`operator+=`用于在字符串末尾追加内容,并展示了不同重载形式。`append`函数提供了更多追加选项,包括子串、字符数组、单个字符等。`push_back`和`pop_back`分别用于在末尾添加和移除一个字符。`assign`用于替换字符串内容,而`insert`允许在任意位置插入字符串或字符。最后,`erase`函数用于删除字符串中的部分内容。每个函数都配以代码示例和说明。