【C++】类模板(template)----存放未知个数的元素

需求:写一个可变长度的数组类Array,用于存放若干元素,个数未知

设计:内部动态申请一个buffer

           capacity:表示buffer的大小

           size:表示buffer中已经存放元素的个数

#include "stdafx.h"
#include <stdio.h>
#include <string.h>

template <typename T>//也可以写作template <class T>
class Array
{
public:
    Array(int capacity = 4)
    {
        m_buffer = new T[capacity];
        m_capacity = capacity;
        m_size = 0;
    }
    void PushBack(T val)
    {
        if (m_size >= m_capacity)
        {
            Resize();
        }
        m_buffer[m_size] = val;
        m_size++;
    }

    int Capacity()
    {
        return m_capacity;
    }

    int Size()
    {
        return m_size;
    }
private:
    void Resize()
    {
        //创建一个更大的缓冲区
        int n = m_capacity + 4;
        T* buf = new T[n];

        //拷贝所有内容
        memcpy(buf, m_buffer, m_capacity);

        //删除旧的内存
        delete[] m_buffer;

        //更新成员变量
        m_capacity = n;
        m_buffer = buf;
    }
private:
    T* m_buffer;
    int m_capacity; //容量
    int m_size; //已经存放的对象的个数
};

int main()
{
    Array <int> a; //也可以是Array <int> a(4);
    a.PushBack(1);
    a.PushBack(2);
    a.PushBack(3);
    a.PushBack(4);

    a.PushBack(5);

    int size = a.Size();
    int capacity = a.Capacity();
    return 0;
}

从 Array <int> a; //也可以是Array <int> a(4);  这段代码表明如果Array构造函数中有默认值的参数时,你可以给传参也可以不传参,他都会进入Array(int capacity = 4){}这个构造函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值