gof设计模式——抽象工厂 c++实现

简介:

 最近抽空看了看gof的设计模式,感觉理解上有一定难度,而且即使看的时候理解了,用的时候也忘了,为了加深印象,把书上的一个应用场景用c++实现一下,因为平时较少用设计模式,理解上难免有误,错误之处望指正,不胜感激。

意图

    提供一个创建一系列相关活相互依赖对象的接口,而无需指定他们具体的类

    个人理解:不暴露所用组件的具体实现,只提供使用相关类的接口,可维护性强。

实用性

  •     一个系统要独立于它的产品的创建、组合和表示时。
  •     有一个系统要有多个产品系列中的一个来配置时。
  •     当你要强调一系列相关的产品对象的设计以便进行联合使用时。
  •     当你提供一个产品类库,而只想显示它们的接口而不是实现时。

结构 

 抽象工厂

ps:要画图的时候发现没装visio,用Diagram Designer画的,画的很挫,但是清晰一点,也和下面的程序对应,网上找的图有点模糊。


实现


1 /* 抽象工厂 shapherd */
 2 
 3 #include<iostream>
 4 using namespace std;
 5 
 6 class Window {
 7     public:
 8         virtual ~Window() {}
 9         //virtual ~Window() = 0;   
10 };
11 
12 class PMWindow : public Window {
13     public:
14         PMWindow()
15         {
16             cout<<"PMWindow created"<<endl;
17         }
18 };
19 class MotifWindow : public Window {
20     public:
21         MotifWindow()
22         {
23             cout<<"motifWindow created"<<endl;
24         }  
25 };
26 
27 class ScrollBar{
28     public:
29         virtual ~ScrollBar() {}
30 };
31 
32 class PMScrollBar : public ScrollBar {
33     public:
34         PMScrollBar()
35         {
36             cout<<"PMScrollbar created"<<endl;
37         }
38 };
39 class MotifScrollBar : public ScrollBar {
40     public:
41         MotifScrollBar()
42         {
43             cout<<"MotifScrollbar created " <<endl;
44         }
45 };
46 
47 class WidgetFactory {
48     public:
49         virtual ~WidgetFactory() {}
50         virtual ScrollBar* CreatScrollBar() = 0;
51         virtual Window* CreatWindow() = 0;
52 };
53 
54 class PMWidgetFactory : public WidgetFactory {
55     ScrollBar* CreatScrollBar()
56     {
57         return new PMScrollBar;
58     }
59     Window* CreatWindow()
60     {
61         return new PMWindow;
62     }
63 };
64 class MotifWidgetFactory : public WidgetFactory {
65     ScrollBar* CreatScrollBar()
66     {
67         return new MotifScrollBar;
68     }
69     Window* CreatWindow()
70     {
71         return new MotifWindow;
72     }
73 };
74 
75 int main(int argc, char* argv[])
76 {
77     WidgetFactory *wfOfPM = new PMWidgetFactory();
78     wfOfPM->CreatWindow();
79     wfOfPM->CreatScrollBar();
80     delete wfOfPM;
81     WidgetFactory *wfOfMotif = new MotifWidgetFactory();
82     wfOfMotif->CreatWindow();
83     wfOfMotif->CreatScrollBar();
84     delete wfOfMotif;
85 }
86 

遇到的问题

  1.  因为好久没用vim了,忘记了用管理员权限创建文件,结果乱写一气,写完了用wq肯定是不能保存的,在上面点右键copy也不可用,linux方面不太熟悉,纠结了半天,最后查到一个命令 w ! sudo tee %
  2. 积累没有实例化,但是析构函数生命为纯虚函数就报错, virtual ~Window() = 0;这句在linux下会报 undefined reference to `Window::~Window()' 错误,在windows会报error LNK2019: unresolved external symbol "public: virtual __thiscall Window::~Window(void)"错误,无奈之下仅能声明为虚函数了。我怀疑是不是因为工厂类里面返回了Window* 指针,但是这也不是实例化Window类啊,求解!
目录
相关文章
|
30天前
|
设计模式 安全 测试技术
【C/C++ 设计模式 单例】单例模式的选择策略:何时使用,何时避免
【C/C++ 设计模式 单例】单例模式的选择策略:何时使用,何时避免
61 0
|
1月前
|
设计模式 算法 C++
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程(二)
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程
26 0
|
1月前
|
设计模式 存储 uml
C++ 设计模式实战:外观模式和访问者模式的结合使用,派生类访问基类的私有子系统
C++ 设计模式实战:外观模式和访问者模式的结合使用,派生类访问基类的私有子系统
29 1
|
28天前
|
设计模式 算法 中间件
【C++ 可调用对象的应用】C++设计模式与现代编程技巧:深入可调用对象的世界
【C++ 可调用对象的应用】C++设计模式与现代编程技巧:深入可调用对象的世界
113 1
|
30天前
|
设计模式 关系型数据库 数据库
【C++ 设计模式 工厂模式对比】深入探索设计模式:工厂方法与抽象工厂的比较与对照
【C++ 设计模式 工厂模式对比】深入探索设计模式:工厂方法与抽象工厂的比较与对照
21 1
|
1月前
|
设计模式 存储 算法
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程(三)
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程
24 0
|
1月前
|
设计模式 算法 搜索推荐
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程(一)
【C++ 泛型编程 进阶篇】C++元模板编程与设计模式的结合应用教程
39 0
|
16天前
|
设计模式 SQL 算法
设计模式了解哪些,模版模式
设计模式了解哪些,模版模式
19 0
|
1月前
|
设计模式 Java uml
C++设计模式之 依赖注入模式探索
C++设计模式之 依赖注入模式探索
37 0
|
2月前
|
设计模式 前端开发 JavaScript
观察者模式 vs 发布-订阅模式:两种设计模式的对决!
欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。