原型模式——C++实现

向量的原型

用C++完成数学中向量的封装,其中,用指针和动态申请支持向量长度的改变,使用浅克隆和深克隆复制向量类,比较这两种克隆方式的异同。

类图:

 

浅克隆C++代码:

#include <iostream>
using namespace std;
//向量类
class Vector{
private:
    int *p;
    int len;
public:
    Vector(int len);
    Vector(const Vector &vector);  //拷贝构造函数
    ~Vector();
    int operator[](int i) const { return p[i]; }
    int &operator[](int i){ return p[i]; }
    int length() const { return len; }
};
Vector::Vector(int len): len(len){
    p = (int*)calloc( len, sizeof(int) );
}
//拷贝构造函数
Vector::Vector(const Vector &vector){
    this->len = vector.len;
    this->p = vector.p;
}
Vector::~Vector(){ free(p); }
//打印
void display(const Vector &vector){
    int len = vector.length();
    for(int i=0; i<len; i++){
        if(i == len-1){
            cout<<vector[i]<<endl;
        }else{
            cout<<vector[i]<<", ";
        }
    }
}
int main(){
    Vector v1(10);
    for(int i=0; i<10; i++){
        v1[i] = i;
    }
    Vector v2 = v1;
    v2[6] = 55;
    v2[2] = 20;
    cout<<"浅克隆:"<<endl;
    cout<<"更改copyVector后vector的数据:"<<endl;
    display(v1);
    cout<<"更改copyVector后copyVector的数据:"<<endl;
    display(v2);
    return 0;
}

浅克隆运行结果:

深克隆C++代码:

#include <iostream>
using namespace std;
//向量类
class Vector{
private:
    int *p;
    int len;
public:
    Vector(int len);
    Vector(const Vector &vector);  //拷贝构造函数
    ~Vector();
    int operator[](int i) const { return p[i]; }
    int &operator[](int i){ return p[i]; }
    int length() const { return len; }
};
Vector::Vector(int len): len(len){
    p = (int*)calloc( len, sizeof(int) );
}
//拷贝构造函数
Vector::Vector(const Vector &vector){
    this->len = vector.len;
    this->p =  (int*)calloc( this->len, sizeof(int) );
    memcpy( this->p, vector.p, len * sizeof(int) );
}
Vector::~Vector(){ free(p); }
//打印
void display(const Vector &vector){
    int len = vector.length();
    for(int i=0; i<len; i++){
        if(i == len-1){
            cout<<vector[i]<<endl;
        }else{
            cout<<vector[i]<<", ";
        }
    }
}
int main(){
    Vector v1(10);
    for(int i=0; i<10; i++){
        v1[i] = i;
    }
    Vector v2 = v1;
    v2[6] = 55;
    v2[2] = 20;
    cout<<"深克隆:"<<endl;
    cout<<"更改copyVector后vector的数据:"<<endl;
    display(v1);
    cout<<"更改copyVector后copyVector的数据:"<<endl;
    display(v2);
    return 0;
}

深克隆运行结果:

两种克隆方式异同:

1、在C++中,对一个已知对象进行拷贝,系统会自动调用一种构造函数——拷贝构造函数。

2、如果用户未定义拷贝构造函数,则会调用默认拷贝构造函数,这时进行的是浅拷贝(浅克隆)。即对vector拷贝后出现两个指针指向同一个内存空间。

 

 

 


所以在程序中我们改变
copyVector的内容,vector中的内容也会改变。 


 

 

 

 

3、若我们自己定义拷贝构造函数,使拷贝后的对象指针有自己的内存空间,即进行深拷贝(深克隆)。

 

 

 

此时改变copyVector的内容,vector中的内容不会改变。


  

 

 

#include <iostream>
using namespace std;
//向量类
class Vector{
private:
    int *p;
    int len;
public:
    Vector(int len);
    Vector(const Vector &vector);  //拷贝构造函数
    ~Vector();
    int operator[](int i) const return p[i]; }
    int &operator[](int i){ return p[i]; }
    int length() const return len; }
};
Vector::Vector(int len): len(len){
    p = (int*)calloc( len, sizeof(int) );
}
//拷贝构造函数
Vector::Vector(const Vector &vector){
    this->len = vector.len;
    this->p =  (int*)callocthis->len, sizeof(int) );
    memcpythis->p, vector.p, len * sizeof(int) );
}
Vector::~Vector(){ free(p); }
//打印
void display(const Vector &vector){
    int len = vector.length();
    for(int i=0; i<len; i++){
        if(i == len-1){
            cout<<vector[i]<<endl;
        }else{
            cout<<vector[i]<<", ";
        }
    }
}
int main(){
    Vector v1(10);
    for(int i=0; i<10; i++){
        v1[i] = i;
    }
    Vector v2 = v1;
    v2[6] = 55;
    v2[2] = 20;
    cout<<"深克隆:"<<endl;
    cout<<"更改copyVector后vector的数据:"<<endl;
    display(v1);
    cout<<"更改copyVector后copyVector的数据:"<<endl;
    display(v2);
    return 0;
}
posted @ 2022-09-30 20:13  好(justice)……  阅读(38)  评论(0编辑  收藏  举报