现在的位置: 首页 > 综合 > 正文

factory mothed pattern–工厂方法模式

2017年12月13日 ⁄ 综合 ⁄ 共 1398字 ⁄ 字号 评论关闭

factory mothed pattern,称工厂方法模式

首先我们看看Gof怎么定义工厂方法模式的:

“Define an interface for creating an object, but let subclasses decide which class to instantiate. Factory Method lets a class defer instantiation to subclasses.”  - GoF

"为创建一个对象而定义一个接口,让子类决定哪个类实例化,工厂方法模式使类的实例化延迟到子类"-GoF

抽象工厂(AbstractFactory)     是工厂方法模式的核心。具体工厂必须实现在抽象工厂中定义的抽象方法。

具体工厂(ConcreteFactory)   实现抽象工厂中定义的所有抽象方法,包含与业务密切相关的逻辑。

抽象产品(AbstractProduct)     所有具体产品的超类,亦即具体产品的共同父类。

具体产品(ConcreteProduct)   这个角色实现了抽象产品角色所定义的接口。

在C++中,其实就是运用的C++多态性质。
实例:
一个工厂生产奔驰轿车,一个工厂生成奥迪轿车,同时要进行测试。
 1 class Car
 2 {
 3     public:
 4         virtual void run( )=0;
 5 };
 6 
 7 class AudiCar:public Car
 8 {
 9     public:
10         void run( );
11 };
12 void AudiCar::run( )
13 {
14         std::cout<<"Audi is running"<<std::endl;
15 } 
16 
17 class BenzCar:public Car
18 {
19     public:
20         void run( );
21 }
22 void BenzCar::run( )
23 {
24         std::cout<<"Benz is running"<<std::endl;
25 };
26 
27 class CarFactory
28 {
29     public:
30        virtual Car * createCar( )=0;
31 };
32 
33 class AudiCarFactory:public CarFactory
34 {
35     public:
36         Car * createCar( );
37 };
38 Car * AudiCarFactory::createCar( )
39 {
40         return new AudiCar( );
41 }
42 
43 class BenzCarFactory:public CarFactory
44 {
45     public:
46         Car * createCar( );
47 };
48 Car* BenzCarFactory::createCar( )
49 {
50         return new BenzCar( );
51 }
52 
53 void createAndTest(CarFactory* p)
54 {
55     car* c=p->createCar( );
56     c->run( );
57     delete c;
58 }
59 
60 int main (int argc,char* argv)
61 {
62     CarFactory * p1 =new BenzCarFactory( );        //由子类决定实例化对象
63     CarFactory * p2 =new AudiCarFactory( );
64     createAndTest(p1);
65     createAndTest(p2);
66     delete p1;
67     delete p2;
68     return 0;
69 }

 

运行结果:

抱歉!评论已关闭.