#ifndef _ARRAY_H_

#define _ARRAY_H_

/*

*实现一个数组类模板,在栈上

*why

*2016/9/5

*/

template

< typename T, int N >

class Array

{

private:

T m_array[N];

public:

int length(); //获取数组长度

bool set_array(T value, int index); //设置数组元素内容

bool get_array(T& value, int index);//获取数组元素内容

T& operator [](int index);//重载[]操作符,方便数组对象的操作

T operator [](int index) const;//如果用户定义的是const的数组对象,那么访问数组元素时,就需要用const修饰的成员函数

virtual ~Array();//析构函数最好定义成虚函数,可以让继承此类的类重写这个析构函数。当然这里可以不是vitrual的,因为如果构造函数是private而不是protected,

//就是不想让这个类被继承,所以可以不用vitrual,但如果构造函数等是protected的,说明是想被继承的,如果想被继承,那么析构函数最好是virtual的

};


template

< typename T, int N >

int Array<T, N>::length()

{

return N;

}


template

< typename T, int N >

bool Array<T, N>::set_array(T value, int index)

{

bool ret = (0 <= index) && (index < N);

if (ret)

{

m_array[index] = value;

}

return ret;

}


template

< typename T, int N >

bool Array<T, N>::get_array(T& value, int index)

{

bool ret = (0 <= index) && (index < N);

if (ret)

{

value = m_array[index];

}

return ret;

}


template

< typename T, int N >

T& Array<T, N>::operator[](int index)

{

return m_array[index];

}


template

< typename T, int N >

T Array<T, N>::operator[](int index) const

{

return m_array[index];

}



template

< typename T, int N >

Array<T, N>::~Array()

{

}



#endif