原型模式
用C++完成数学中向量的封装,其中,用指针和动态申请支持向量长度的改变,使用浅克隆和深克隆复制向量类,比较这两种克隆方式的异同。
类图:
代码:
#include<cmath>
#include<iostream>
using namespace std;
class Vector{
private:
double *array =new double[4];
double length;
public:
Vector(double arr[4])
{
this->array[0] = arr[0];
this->array[1] = arr[1];
this->array[2] = arr[2];
this->array[3] = arr[3];
this->length = sqrt(((arr[0] - arr[1])*(arr[0] - arr[1])) + ((arr[2] - arr[3])*(arr[2] - arr[3])));
}
~Vector()
{
delete[]array;
this->length = 0;
}
Vector* clone()
{
return new Vector(*this);
}
Vector(const Vector& vector)
{
//浅克隆
this->array = vector.array;
this->length = vector.length;
}
void show()
{
cout << "向量长度:" << this->length << endl;
}
};
int main()
{
double s[4] = { 1, 2, 3, 4 };
Vector* v1 = new Vector(s);
Vector* v2 = v1->clone();
v1->show();
v2->show();
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义