《新标准C++程序设计》4.5(C++学习笔记15)

实例:长度可变的整型数组类

int main() { //要编写可变长整型数组类,使之能如下使用:
    CArray a; //开始里的数组是空的
    for (int i = 0; i < 5; ++i)
        a.push_back(i);//->要用动态分配的内存来存放数组元素,需要一个指针成员变量
    CArray a2, a3;
    a2 = a;//->要重载“=”
    for (int i = 0; i < a.length(); ++i)
        cout << a2[i] << " ";//->要重载“[ ]”
    a2 = a3; //a2是空的
    for (int i = 0; i < a2.length(); ++i) //a2.length()返回0
        cout << a2[i] << " ";
    cout << endl;
    a[3] = 100;
    CArray a4(a);//->要自己写复制构造函数
    for (int i = 0; i < a4.length(); ++i)
        cout << a4[i] << " ";
    return 0;
}
class CArray {
    int size; //数组元素的个数
    int* ptr; //指向动态分配的数组
public:
    CArray(int s = 0); //s代表数组元素的个数
    CArray(CArray& a);
    ~CArray();
    void push_back(int v); //用于在数组尾部添加一个元素v
    CArray& operator=(const CArray& a);
    //用于数组对象间的赋值
    int length() { return size; } //返回数组元素个数
    int& CArray::operator[](int i) //返回值为 int 不行!不支持 a[i] = 4
    {//用以支持根据下标访问数组元素,
    // 如n = a[i] 和a[i] = 4; 这样的语句
        return ptr[i];
    }
};
CArray::CArray(int s) :size(s)
{//构造函数
    if (s == 0)
        ptr = NULL;
    else
        ptr = new int[s];
}
CArray::CArray(CArray& a) {//复制构造函数
    if (!a.ptr) {
        ptr = NULL;
        size = 0;
        return;
    }
    ptr = new int[a.size];
    memcpy(ptr, a.ptr, sizeof(int) * a.size);
    size = a.size;
}
CArray::~CArray()//析构函数
{
    if (ptr) delete[] ptr;
}
CArray& CArray::operator=(const CArray& a)
{ //赋值号的作用是使“=”左边对象里存放的数组,大小和内容都和右边的对象一样
        if (ptr == a.ptr) //防止a=a这样的赋值导致出错
            return *this;
    if (a.ptr == NULL) { //如果a里面的数组是空的
        if (ptr) delete[] ptr;
        ptr = NULL;
        size = 0;
        return *this;
    }
}
if (size < a.size) { //如果原有空间够大,就不用分配新的空间
    if (ptr)
        delete[] ptr;
    ptr = new int[a.size];
}
memcpy(ptr, a.ptr, sizeof(int) * a.size);
size = a.size;
return *this;
} // CArray & CArray::operator=( const CArray & a)
void CArray::push_back(int v)
{ //在数组尾部添加一个元素
    if (ptr) {
        int* tmpPtr = new int[size + 1]; //重新分配空间
        memcpy(tmpPtr, ptr, sizeof(int) * size); //拷贝原数组
        内容
            delete[] ptr;
        ptr = tmpPtr;
    }
    else //数组本来是空的
        ptr = new int[1];
    ptr[size++] = v; //加入新的数组元素
}

 

posted @ 2020-02-13 19:31  沐沐Y  阅读(189)  评论(0编辑  收藏  举报