首页 > 其他分享 >软件设计Tutorial 6_原型模式

软件设计Tutorial 6_原型模式

时间:2023-11-14 14:35:49浏览次数:29  
标签:index 软件设计 double int 原型 new data Tutorial size

[实验任务一]:向量的原型

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

实验要求:

1.  画出对应的类图;

 

 

2.  提交源代码(用C++完成);

 

#include <iostream>

#include <cstring>

 

class Vector {

private:

    int size;

    double *data;

 

public:

    // 构造函数

    Vector(int size) {

        this->size = size;

        data = new double[size];

    }

 

    // 析构函数

    ~Vector() {

        delete[] data;

    }

 

    // 复制构造函数

    Vector(const Vector& other, bool deep_clone = true) {

        size = other.size;

        data = new double[size];

        if (deep_clone) {  

            std::memcpy(data, other.data, size * sizeof(double));   //深克隆

        } else {

            data = other.data; // 浅克隆,共享底层数组

        }

    }

 

    // 重设向量大小

    void resize(int new_size) {

        double *new_data = new double[new_size];

        int min_size = (new_size < size) ? new_size : size;

        std::memcpy(new_data, data, min_size * sizeof(double));

        delete[] data;

        data = new_data;

        size = new_size;

    }

 

    // 获取向量大小

    int getSize() const {

        return size;

    }

 

    // 获取向量元素

    double get(int index) const {

        if (index >= 0 && index < size) {

            return data[index];

        } else {

            std::cerr << "Index out of bounds." << std::endl;

            return 0.0; // 默认返回值

        }

    }

 

    // 设置向量元素

    void set(int index, double value) {

        if (index >= 0 && index < size) {

            data[index] = value;

        } else {

            std::cerr << "Index out of bounds." << std::endl;

        }

    }

};

 

int main() {

    // 创建一个向量对象

    Vector vector1(5);

    vector1.set(0, 1.0);

    vector1.set(1, 2.0);

    vector1.set(2, 3.0);

 

    // 浅克隆

    Vector vector2(vector1, false);

    vector2.set(0, 10.0);

    std::cout << "Vector1[0]: " << vector1.get(0) << std::endl;

 

    // 深克隆

    Vector vector3(vector1);

    vector3.set(0, 20.0);

    std::cout << "Vector1[0]: " << vector1.get(0) << std::endl;

 

    return 0;

}

 

标签:index,软件设计,double,int,原型,new,data,Tutorial,size
From: https://www.cnblogs.com/JJTyyds/p/17831491.html

相关文章

  • 软件设计实验12:外观模式
    [实验任务一]:计算机开启在计算机主机(Mainframe)中,只需要按下主机的开机按钮(on()),即可调用其他硬件设备和软件的启动方法,如内存(Memory)的自检(check())、CPU的运行(run())、硬盘(HardDisk)的读取(read())、操作系统(OS)的载入(load()),如果某一过程发生错误则计算机启动失败。......
  • 软件设计Tutorial 13_享元模式
    [实验任务一]:围棋设计一个围棋软件,在系统中只存在一个白棋对象和一个黑棋对象,但是它们可以在棋盘的不同位置显示多次。实验要求:1. 提交类图;  2.提交源代码;3.注意编程规范;4.要求用简单工厂模式和单例模式实现享元工厂类的设计。 packageXiang;publicclassBla......
  • 番外-软件设计(9)
    在计算机主机(Mainframe)中,只需要按下主机的开机按钮(on()),即可调用其他硬件设备和软件的启动方法,如内存(Memory)的自检(check())、CPU的运行(run())、硬盘(HardDisk)的读取(read())、操作系统(OS)的载入(load()),如果某一过程发生错误则计算机启动失败。实验要求:1. 提交类图;......
  • 番外-软件设计(10)
    设计一个围棋软件,在系统中只存在一个白棋对象和一个黑棋对象,但是它们可以在棋盘的不同位置显示多次。实验要求:1. 提交类图; 2.提交源代码;packageEnjoy_element_pattern; publicclassClient{    publicstaticvoidmain(String[]args){        Chess......
  • 软件设计模式学习每日总结-第一天
    Uml类图1、分三层,从上至下分别为类名,属性,方法。2、类与类之间的关系:关联(聚合,组合)、依赖、继承、实现。3、依赖是最低耦合,继承是最高耦合。  七大原则1、开闭原则:程序代码对扩展开发,对修改关闭。2、里氏代换原则:子类可以扩展父类功能,但是不要修改父类原有的功能。3......
  • Java的设计模式之原型模式
    在某些情况下,需要创建对象的副本,但是复制一个对象的成本可能很高,或者希望避免与对象的具体类耦合。例如,当创建对象的过程较为复杂,或者对象包含大量共享的状态时,使用常规的创建方法可能会导致性能下降。原型模式的解决方案是通过复制现有对象来创建新对象,而不是从头开始构建。这允许......
  • 软件设计实验10:组合模式
    实验10:组合模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容:1、理解组合模式的动机,掌握该模式的结构;2、能够利用组合模式解决实际问题。 [实验任务一]:组合模式用透明组合模式实现教材中的“文件夹浏览”这个例子。实验要求:1. 文件的执行不需真正实现,只需简单......
  • 软件设计实验11:装饰模式
    实验11:装饰模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 1、理解装饰模式的动机,掌握该模式的结构;2、能够利用装饰模式解决实际问题。 [实验任务一]:手机功能的升级用装饰模式模拟手机功能的升级过程:简单的手机(SimplePhone)在接收来电时,会发出声音提醒主人;而......
  • 每日随笔——原型模式
    [实验任务一]:向量的原型用C++完成数学中向量的封装,其中,用指针和动态申请支持向量长度的改变,使用浅克隆和深克隆复制向量类,比较这两种克隆方式的异同。实验要求:1.画出对应的类图;2.提交源代码(用C++完成);3.注意编程规范。类图 源码:#include<cmath>#include<iostream>usi......
  • ScholarAI ChatGPT Plugin Tutorial, Use Cases & Prompts
    https://roihacks.com/scholarai-chatgpt-plugin/?utm_source=youtube&utm_medium=social&utm_campaign=scholarai-chatgpt-plugin......