写个简单的管理数组指针的智能指针

模板智能数组指针

1.管理任意类型的数组指针

2.释放的时候自动删除数组指针指向的内存

复制代码
//模板智能数组指针
template<typename T>
class AiArrayPtr
{
public:
     AiArrayPtr(T *pArray)
    {
        m_pAiPtr = pArray;
        m_bIsMyPtr =true;//是自己管理的指针
        m_nSize = GetArraySize(pArray);//计算数组在内存中的个数
    }
  ~AiArrayPtr(){
    if(m_pAiPtr && m_bIsMyPtr)//指针不为空并且是自己管理的指针
    { 
      delete[] m_pAiPtr;
      m_pAiPtr=nullptr;
    }
   }
private:
  T* m_pAiPtr;    //保存数组指针
  bool m_bIsMyPtr;  //是否自己删除数组指针
  int m_nSize;    //数组大小
};

3.通过指针计算数组中的个数

复制代码
//通过指针获取数组个数
int GetArraySize(const T  *pArray)const
{
    const char* pname = typeid(T).name(); //获得类型名称
    int s = 0;

    //检查是否是结构体sturct 或是类class
    if (strstr(pname, "struct") || strstr(pname, "class"))
    {
        s = *((size_t*)pArray - 1); //获取对象数组个数
    }
    else
    {
        s = _msize(pArray) / sizeof(T); //获取内置数据数组个数
    }
    return s;
}

3.要有指针的样式和数组的样式

复制代码
//重载->运算符
const AiArrayPtr* operator->()const {
     return this; }

//重载[]运算符
T operator[](int index) { 
    if (index < 0 || index >= m_nSize)
    {
        throw(TEXT("数组越界"));
            return T();
    }
    return *(m_pAiPtr + index);
 }

4.支持for范围查询和迭代器

复制代码
//AiArrayPtr的类中类迭代器
class iterator
{
private:
    T* m_pCur;  //当前指针数据
public:
    iterator(T* pCur)
        :m_pCur(pCur) {}

    T operator*() { //迭代器解引用
        return *m_pCur; 
    }

    iterator& operator++() { //前置++运算符
        m_pCur++; return *this; 
    }

    iterator& operator++(int) { //后置++运算符
        m_pCur++; return *this; 
    }

    bool operator==(iterator const& it)const { //==运算符
        return m_pCur == it.m_pCur; 
    }

    bool operator!=(iterator const &it)const { //!=运算符
        return !(*this == it); 
    }
};

//在AiArrayPtr类实现bigin()和end()函数
iterator begin()const { //范围开始
  return iterator(m_pAiPtr); 
}

iterator end()const { //范围结束
  return iterator(m_pAiPtr + m_nSize); 
}

5.实例用法

复制代码
AiArrayPtr<int> pint = new int[3]{ 4,5,6 };

int nSize=pint->GetSize();//指针样式用法

int n = pint[2];//数组样式用法

    for (const int &v : pint)//支持新的for范围查询
    {
        OutString(TEXT("V= %d"), v);
    }

//支持以前的for范围查询
for (AiArrayPtr<int>::iterator it = pint->begin();
   it != pint->end(); it++)
{
  OutString(TEXT("V= %d"), *(it));
}
相关推荐
无限进步_7 分钟前
【C++】私有虚函数与多态:访问权限不影响动态绑定
开发语言·c++·ide·windows·git·算法·visual studio
努力努力再努力wz9 分钟前
【MySQL入门系列】:不只是建表:MySQL 表约束与 DDL 执行机制全解析
android·linux·服务器·数据结构·数据库·c++·mysql
艾莉丝努力练剑29 分钟前
【Linux加餐】mmap文件映射
linux·运维·服务器·c语言·c++·学习
叶子野格35 分钟前
《C语言学习:编程例题》8
c语言·开发语言·c++·学习·算法·visual studio
6Hzlia40 分钟前
【Hot 100 刷题计划】 LeetCode 152. 乘积最大子数组 | C++ 动态规划 (绝妙 swap 翻转技巧)
c++·leetcode·动态规划
HockerF44 分钟前
cpu原理到c/c++指针
c语言·c++
John.Lewis1 小时前
C++加餐课-二叉树:进阶算法
数据结构·c++·算法
Q741_1471 小时前
设计模式之装饰器模式 理论总结 C++代码实战
c++·设计模式·装饰器模式
脱氧核糖核酸__1 小时前
LeetCode热题100——54.螺旋矩阵(题解+答案+要点)
c++·算法·leetcode·矩阵
!停1 小时前
C++入门STL容器string底层剖析
开发语言·c++