c加加程序设计语言,c加加程序设计?

1.理解下面的动态数组类模板,它由一系列位置连续、任意数量相同类型的元素组成,其元素个数可在程序运行时改变,并完成该类中没有完成的成员函数(不允许改变已有代码),并设计主函数,实现对该模板类的功能测试。

#include

#include

//容错处理

enum ErrorType

{

invalidArraySize,memoryAllocatetionError,indexOutOfRang

};

char *errorMsg[] =

{

"Invalid array size",

"Memory allocation error",

"Invalid index"

};

template

class Array

{

private:

T* alist;

int size;

void Error(ErrorType error) const;//输出错误信息

public:

Array(int sz=50);//构造函数

Array(const Array& X);//拷贝构造函数

~Array(void);//析构函数

Array& operator=(const Array& rhs);//重载赋值运算符

T& operator[](int i);//重载下标运算符

int GetSize(void) const;//获取数组大小

void Resize(int sz);//重新设置数组大小

};

template

Array::Array(int sz)

{

if(sz <= 0)

Error(invalidArraySize);

size = sz;

alist = new T[size];

if(alist == 0)

Error(memoryAllocatetionError);

}

template

Array::Array(const Array& X)

{

int n = X.size;

size = n;

alist = new T[n];

if(alist == 0)

Error(memoryAllocatetionError);

T* srcptr = X.alist;

T* destptr = alist;

while(n--)

*destptr++ = *srcptr++;

}

template

Array::~Array()

{

delete[] alist;

}

template

Array& Array::operator=(const Array &rhs)

{

int n = rhs.size;

if(size != n)

{

delete[] alist;

alist = new T[n];

if(alist == 0)

Error(memoryAllocatetionError);

size = n;

}

T* destptr = alist;

T* srcptr = rhs.alist;

while(n--)

*destptr++ = *srcptr++;

return *this;

}

template

T& Array::operator[](int n)

{

if(n < 0 || n > size-1)

Error(indexOutOfRang);

return alist[n];

}

void main()

{

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值