gpt4 book ai didi

实例讲解C++编程中对设计模式中的原型模式的使用

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章实例讲解C++编程中对设计模式中的原型模式的使用由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

原型模式的实现完整代码示例(code):原型模式的实现很简单,这里为了方便初学者的学习和参考,将给出完整的实现代码(所有代码采用 C++实现,并在 VC 6.0 下测试运行).

代码片断 1:Prototype.h 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//Prototype.h
#ifndef _PROTOTYPE_H_
#define _PROTOTYPE_H_
class Prototype{
  public :
  virtual ~Prototype();
  virtual Prototype* Clone() const = 0;
  protected :
  Prototype();
  private :
};
class ConcretePrototype: public Prototype{
  public :
  ConcretePrototype();
  ConcretePrototype( const ConcretePrototype& cp);
  ~ConcretePrototype();
  Prototype* Clone() const ;
  protected :
  private :
};
#endif //~_PROTOTYPE_H_

代码片断 2:Prototype.cpp 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//Prototype.cpp
#include "Prototype.h"
#include <iostream>
using namespace std;
Prototype::Prototype(){
}
Prototype::~Prototype(){
}
Prototype* Prototype::Clone() const {
  return 0;
}
ConcretePrototype::ConcretePrototype(){
}
ConcretePrototype::~ConcretePrototype(){
}
ConcretePrototype::ConcretePrototype( const ConcretePrototype& cp){
  cout<< "ConcretePrototype copy ..." <<endl;
}
Prototype* ConcretePrototype::Clone() const {
  return new ConcretePrototype(* this );
}

代码片断 3:main.cpp 。

?
1
2
3
4
5
6
7
8
9
//main.cpp
#include "Prototype.h"
#include <iostream>
using namespace std;
int main( int argc, char * argv[]){
  Prototype* p = new ConcretePrototype();
  Prototype* p1 = p->Clone();
  return 0;
}

代码说明:原型模式的结构和实现都很简单,其关键就是(C++中)拷贝构造函数的实现方式,这也是 C++实现技术层面上的事情。由于在示例代码中不涉及到深层拷贝(主要指有指针、复合对象的情况),因此我们通过编译器提供的默认的拷贝构造函数(按位拷贝)的方式进行实现。说明的是这一切只是为了实现简单起见,也因为本文档的重点不在拷贝构造函数的实现技术,而在原型模式本身的思想.

另一个实例 。

我们再来看一个具体项目的例子:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
namespace Prototype_DesignPattern
{
  using System;
 
  // Objects which are to work as prototypes must be based on classes which
  // are derived from the abstract prototype class
  abstract class AbstractPrototype
  {
   abstract public AbstractPrototype CloneYourself();
  }
 
  // This is a sample object
  class MyPrototype : AbstractPrototype
  {
   override public AbstractPrototype CloneYourself()
   {
    return ((AbstractPrototype)MemberwiseClone());
   }
   // lots of other functions go here!
  }
 
  // This is the client piece of code which instantiate objects
  // based on a prototype.
  class Demo
  {
   private AbstractPrototype internalPrototype;
 
   public void SetPrototype(AbstractPrototype thePrototype)
   {
    internalPrototype = thePrototype;  
   }
 
   public void SomeImportantOperation()
   {
    // During Some important operation, imagine we need
    // to instantiate an object - but we do not know which. We use
    // the predefined prototype object, and ask it to clone itself.
 
    AbstractPrototype x;
    x = internalPrototype.CloneYourself();
    // now we have two instances of the class which as as a prototype
   }
  }
 
  /// <summary>
  /// Summary description for Client.
  /// </summary>
  public class Client
  {
   public static int Main(string[] args)
   {     
    Demo demo = new Demo();
    MyPrototype clientPrototype = new MyPrototype();
    demo.SetPrototype(clientPrototype);
    demo.SomeImportantOperation();
 
    return 0;
   }
  }
}

C#对原型模式的支持 。

在C#里面,我们可以很容易的通过Clone()方法实现原型模式。任何类,只要想支持克隆,必须实现C#中的ICloneable接口。ICloneable接口中有一Clone方法,可以在类中复写实现自定义的克隆方法。克隆的实现方法有两种:浅拷贝(shallow copy)与深拷贝(deep copy)。 浅拷贝与深拷贝 。

下面给出浅拷贝与深拷贝的两个例子,例子使用了ICloneable接口。C#中的数组是引用型的变量,我们通过数组来进行演示:

浅拷贝:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
using System;
 
class ShallowCopy : ICloneable
{
  public int [] v = {1,2,3};
 
  public Object Clone()
  {
  return this .MemberwiseClone();
  }
 
  public void Display()
  {
  foreach( int i in v)
   Console.Write( i + ", " );
  Console.WriteLine();
  }
}
 
class Client
{
  public static void Main()
  {
  ShallowCopy sc1 = new ShallowCopy();
  ShallowCopy sc2 = (ShallowCopy)sc1.Clone();
  sc1.v[0] = 9;
 
  sc1.Display();
  sc2.Display();
  }
}

ShallowCopy对象实现了一个浅拷贝,因此当对sc1进行克隆时,其字段v并没有克隆,这导致sc1与sc2的字段v都指向了同一个v,因此,当修改了sc1的v[0]后,sc2的v[0]也发生了变化.

深拷贝:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
using System;
 
class DeepCopy : ICloneable
{
  public int [] v = {1,2,3};
 
  // 默认构造函数
  public DeepCopy()
  {
  }
 
  // 供Clone方法调用的私有构造函数
  private DeepCopy( int [] v)
  {
  this .v = ( int [])v.Clone();
  }
 
  public Object Clone()
  {
  // 构造一个新的DeepCopy对象,构造参数为
  // 原有对象中使用的 v
  return new DeepCopy( this .v);
  }
 
  public void Display()
  {
  foreach( int i in v)
   Console.Write( i + ", " );
  Console.WriteLine();
  }
}
 
class Client
{
  public static void Main()
  {
  DeepCopy dc1 = new DeepCopy();
  DeepCopy dc2 = (DeepCopy)dc1.Clone();
  dc1.v[0] = 9;
 
  dc1.Display();
  dc2.Display();
  }
}

关于原型模式的讨论 。

原型模式通过复制原型(原型)而获得新对象创建的功能,这里原型本身就是"对象工厂"(因为能够生产对象),实际上原型模式和 Builder 模式、AbstractFactory 模式都是通过一个类(对象实例)来专门负责对象的创建工作(工厂对象),它们之间的区别是: Builder 模式重在复杂对象的一步步创建(并不直接返回对象),AbstractFactory 模式重在产生多个相互依赖类的对象,而原型模式重在从自身复制自己创建新类.

最后此篇关于实例讲解C++编程中对设计模式中的原型模式的使用的文章就讲到这里了,如果你想了解更多关于实例讲解C++编程中对设计模式中的原型模式的使用的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com