创建型模式之原型模式实现
来源:互联网 发布:qc归属地 数据库 编辑:程序博客网 时间:2024/05/29 09:18
概念
Prototype模式是一种对象创建型模式,它采取复制原型对象的方法来创建对象的实例。使用Prototype模式创建的实例,具有与原型一样的数据。
1)由原型对象自身创建目标对象。也就是说,对象创建这一动作发自原型对象本身。
2)目标对象是原型对象的一个克隆。也就是说,通过Prototype模式创建的对象,不仅仅与原型对象具有相同的结构,还与原型对象具有相同的值。
3)根据对象克隆深度层次的不同,有浅度克隆与深度克隆。
角色和职责
原型模式主要面对的问题是:“某些结构复杂的对象”的创建工作;由于需求的变化,这些对象经常面临着剧烈的变化,但是他们却拥有比较稳定一致的接口。
一个复杂对象,具有自我复制功能,统一一套接口。
案例
#include <iostream>#include <string.h>using namespace std;class Person{public: virtual Person *Clone() = 0; virtual void printT() = 0; };class JavaProgrammer:public Person{public: JavaProgrammer() { this->m_name = ""; this->m_age = 0; this->m_resume = NULL; } JavaProgrammer(string name,int age) { this->m_name = name; this->m_age = age; this->m_resume = NULL; } ~JavaProgrammer() { if (m_resume != NULL) { free(m_resume); m_resume = NULL; } } virtual Person *Clone() { JavaProgrammer *p = new JavaProgrammer(); *p = *this; return p; } void setResume(char* resume)//注意深拷贝和浅拷贝问题 { m_resume = new char[strlen(resume)+1]; strcpy(m_resume,resume); } virtual void printT() { cout << "m_name:" << m_name.c_str() << "\t" << "m_age:" << m_age << endl; if (m_resume != NULL) { cout << m_resume << endl; } }private: string m_name; int m_age; char *m_resume;};int main(void){ JavaProgrammer javaperson1("张三",30); javaperson1.setResume("我是C++程序员"); Person *person1= javaperson1.Clone(); person1->printT(); //对象javaperson1具有自我复制功能 delete person1; return 0;}
阅读全文
0 0
- 创建型模式之原型模式实现
- 创建型之原型模式
- 创建型模式之原型模式
- 创建型模式之原型(ProtoType)模式
- 创建型模式之原型模式(prototype)
- 设计模式-创建型之原型模式
- 创建型模式之原型模式PROTOTYPE
- 创建型模式之原型模式
- 创建型模式之原型模式
- JAVA设计模式创建型模式之原型模式
- 创建型模式之原型模式和单例模式
- 设计模式之------创建型模式(五)-----原型模式
- (4)设计模式之原型模式(创建型模式)
- Java设计模式之创建型模式--原型模式
- 创建型模式之原型模式(创建工作周报)
- 创建型模式-原型模式
- 创建型模式---原型模式
- 创建型模式--原型模式
- php7安装redis扩展
- Light OJ 1027&&1030&&1038&&1079
- enca dot 是什么意思?
- C++调用API初步创建Windows窗口程序
- 抠图+修图+调色+合成+特效Photoshop核心应用5项修炼pdf
- 创建型模式之原型模式实现
- 自学Java之Java语言(异常、断言和线程)(007day)
- 快速幂
- php 表单令牌防止重复提交原理
- Kotlin笔记(六)类
- 通过配置文件方式配置数据库的隔离级别
- csu:1947: 突然的灵光 +csu:1952: 地下情报员 (中位数)
- 求一个数组,n个元素的不同组合(排列组合问题)
- 搜索二叉树的实现