c++数组类模板(栈内存)

#ifndef _ARRAY_H_

成都创新互联公司是一家专注于做网站、成都网站建设与策划设计,宿城网站建设哪家好?成都创新互联公司做网站,专注于网站建设十载,网设计领域的专业建站公司;建站业务涵盖:宿城等地区。宿城做网站价格咨询:18980820575

#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::length()

{

return N;

}

template 

< typename T, int N >

bool Array::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::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::operator[](int index)

{

return m_array[index];

}

template 

< typename T, int N >

T Array::operator[](int index) const

{

return m_array[index];

}

template 

< typename T, int N >

Array::~Array()

{

}

#endif


网站名称:c++数组类模板(栈内存)
分享URL:http://pcwzsj.com/article/gigggp.html