您的位置:首页 > 其它

指针操作动态数组建立于取消

2013-06-12 09:48 351 查看
/*
*烟台大学:王飞
*时间:2013.6.11
*本段代码的功能:理解熟练运用指针建立专门的数组处理有关数组的操作
*/

#include <iostream>
#include <stdlib.h>
using namespace std;

class MyArray
{
private:
int *arr;		//用于存放动态分配的数组内存首地址
int  size;		//数组大小
public:
MyArray(int sz=50);
MyArray(int a[],int sz);	//由一个内置类型的数组初始化
MyArray(const MyArray &A);	//复制构造函数
~MyArray(void);				//析构函数,注意释放空间
MyArray& operator =(const MyArray &A); //重载“=”使得数组对象可以整体赋值
bool operator == (MyArray& A);	//重载==,使得Array对象能整体判断两个数组是否相等(size相等且对应元素相等)
friend ostream& operator << (ostream& out,MyArray& A);	//重载<<,输出数组
int GetSize(void) const;	//取数组大小;
};
//以下为类成员函数的定义

MyArray::MyArray(int sz)
{
if(sz<=0)
{
cout<<"invalid Array Size!";        //无效的数组
exit(1);
}
size=sz;                         //将元素个数赋值给变量size
arr=new int[size];              //动态分配内存
for(int i=0; i<size; i++)
{
*(arr+i)=0;                   //每个数据初始化为0
}

}

//由一个内置类型的数组初始化
MyArray::MyArray(int a[],int sz)
{
if(sz<=0)
{
cout<<"invalid Array Size";             //无效的数组
exit(1);
}
size=sz;                //将元素个数赋值给变量size
arr=new int[size];      //动态分配内存
for(int i=0; i<size; i++)
*(arr+i)=*(a+i);
}

//析构函数
MyArray::~MyArray(void)
{
if (!arr)
delete [] arr;                  //及时释放空间,释放有new开辟的动态空间,静态数组无法释放
}

//取当前数组大小
int MyArray::GetSize(void) const
{
return size;
}

//复制构造函数
MyArray::MyArray(const MyArray& A)
{

int n=A.size;    //从对象A取得数组大小,并赋给当前对象成员
size=n;             //在传值

arr=new int
;//为对象申请内存并进行出错检测
//从对象A复制数组元素到本对象
int *srcptr=A.arr;//X.arr是对象A的数组首地址
int *destptr=arr;//arr是本对象中的数组首地址
while(n--)
{
*destptr=*srcptr;
destptr++;
srcptr++;
}
}

//重载赋值运算'='
MyArray& MyArray::operator =(const MyArray &A)
{
int n=A.size;//取A数组的大小
//如果本对象中的数组大小和A不同,则删除数组原有的内存,然后重新分配
if (size!=n)
{
delete []arr;
arr=new int
;
size=n;
}

//从rhs向当前对象复制元素
int* destptr=arr;
int* srcptr=A.arr;
while(n--)
{
*destptr=*srcptr;
destptr++;
srcptr++;
}
return *this;      //返回当前对象的引用
}

bool MyArray::operator == (MyArray& A)
{
bool eq=true;
int n=A.size;   //取A数组的大小
if (size!=n)    //大小不一致,数组一定不相等
{
eq=false;
}
else
{
int* destptr=arr;
int* srcptr=A.arr;
while(n--)
{
if(*destptr!=*srcptr)
{
eq=false;     //其中有一个元素不相等,则数组也不相等
break;
}
destptr++;
srcptr++;
}
}
return eq;//返回当前对象的引用
}
//重载输出函数
ostream& operator << (ostream& out, MyArray& A)
{
for (int i = 0; i < A.size; i++)
{
out<<*(A.arr+i)<<'\t';          //地址一个个的访问
}
out<<endl;
return out;
}

//测试函数
int main()
{
int a[10]= {1,2,3,4,5,6,7,8,9,10};
int b[10]= {4,5,6,7,8,9,10,11,12,13};
MyArray arr1(a,10);  //测试用内置的数组初始化新定义的数组对象
MyArray arr2(b,10);
MyArray arr3(10);   //测试只指定大小的新数组对象的初始化,测试构造函数
cout<<arr1;    //测试对<<的重载
cout<<arr2;    //测试对<<的重载
cout<<arr3;    //测试对<<的重载
cout<<"The size of arr1 is: "<<arr1.GetSize()<<endl;   //测试GetSize()成员函数
return 0;
}


输出结果:



心得体会:

对于现在写的程序来看,至少不再是啥都不懂得那个小菜鸟了!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: