#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