抽象工厂的灵活性要比简单工程的灵活性强。

抽象工厂的UML图(第一次画UML图,可能关系和箭头的图意义有错误,但是请不要以建模规范去看图,以最基本的结合后面OC代码,理解相关关系):

抽象工厂原理:
抽象工厂 较 简单工厂 多了抽象级别 而已。

因为需要创建抽象工厂,所以需要工厂管理器:
新建FactoryManager.h和FactoryManager.m:
FactoryManager.h:

 #import <Foundation/Foundation.h>
#import "BaseFactory.h"
#import "AppleFactory.h"
#import "GoogleFactory.h" 在抽象工厂类中为什么需要枚举列举工厂类,因为需要用户指定工厂,
然后让工厂来生产具体产品
typedef enum : NSUInteger { kApple = 0x11,
kGoogle, } EFactoryType; @interface FactoryManager : NSObject /**
* 获取工厂
*
* @param factoryType 工厂类型
*
* @return 创建出的工厂
*/
+ (BaseFactory *)factoryWithBrand:(EFactoryType)factoryType; @end

FactoryManager.h

FactoryManager.m:

 #import "FactoryManager.h"

 @implementation FactoryManager

 + (BaseFactory *)factoryWithBrand:(EFactoryType)factoryType {

     BaseFactory *factory = nil;

     if (factoryType == kApple) {

         factory = [[AppleFactory alloc] init];

     } else if (factoryType == kGoogle) {

         factory = [[GoogleFactory alloc] init];
} return factory;
} @end

FactoryManager.m

===============================================
建立具体工厂对应的父类工厂:
BaseFactory.h:

 #import <Foundation/Foundation.h>
#import "BasePhone.h"
#import "BaseWatch.h" @interface BaseFactory : NSObject /**
* 创建手机
*
* @return 手机
*/
- (BasePhone *)createPhone; /**
* 创建手表
*
* @return 手表
*/
- (BaseWatch *)createWatch; @end

BaseFactory.h

BaseFactory.m:

 #import "BaseFactory.h"

 @implementation BaseFactory

 - (BasePhone *)createPhone {

     return nil;
} - (BaseWatch *)createWatch { return nil;
} @end

BaseFactory.m

========================================================
关于继承的细节:
继承来自父类的方法,就不需要在子类的@interface声明中重写,直接在@implementation实现中实现父类的方法
========================================================
根据继承上面父类工厂新建两个具体工厂子类AppleFactory和GoogleFactory子类:
AppleFactory.h
#import "BaseFactory.h"

@interface AppleFactory : BaseFactory

@end
AppleFactory.m
#import "AppleFactory.h"
#import "iPhone.h"
#import "iWatch.h"

@implementation AppleFactory

- (BasePhone *)createPhone {
    
    return [[iPhone alloc] init];
}

- (BaseWatch *)createWatch {
    
    return [[iWatch alloc] init];
}

@end
=========================================================
GoogleFactory.m
#import "BaseFactory.h"

@interface GoogleFactory : BaseFactory

@end

GoogleFactory.h
#import "GoogleFactory.h"
#import "Android.h"
#import "AndroidWatch.h"

@implementation GoogleFactory

- (BasePhone *)createPhone {
    
    return [[Android alloc] init];
}

- (BaseWatch *)createWatch {
    
    return [[AndroidWatch alloc] init];
}

@end

=========================================================
手机也有抽象的父类
BasePhone.h:
#import <Foundation/Foundation.h>

@interface BasePhone : NSObject

@end
BasePhone.m:
#import "BasePhone.h"

@implementation BasePhone

@end

=========================================================
手机具体的子类
iPhone.h
#import "BasePhone.h"

@interface iPhone : BasePhone

@end

iPhone.m
#import "iPhone.h"

@implementation iPhone

@end

=========================================================
Android.h
#import "BasePhone.h"

@interface Android : BasePhone

@end
Android.m
#import "Android.h"

@implementation Android

@end

=========================================================
手表抽象的类
BaseWatch.h
#import <Foundation/Foundation.h>

@interface BaseWatch : NSObject

@end
BaseWatch.m
#import "BaseWatch.h"

@implementation BaseWatch

@end

=========================================================
手表具体的类
iWatch.h

 #import "iWatch.h"

 @implementation iWatch

 @end

iWatch.h

iWatch.m

 #import "BaseWatch.h"

 @interface AndroidWatch : BaseWatch

 @end

 #import "AndroidWatch.h"

 @implementation AndroidWatch

 @end

iWatch.m

=========================================================
客户端程序>>>>ViewController.m:

 #import "ViewController.h"
#import "FactoryManager.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // 获取工厂
BaseFactory *factory = [FactoryManager factoryWithBrand:kGoogle]; // 创建商品
BasePhone *phone = [factory createPhone];
BaseWatch *watch = [factory createWatch]; NSLog(@"%@ %@", phone, watch);
} @end

ViewController.m

 
 
 

IOS设计模式-抽象工厂的更多相关文章

  1. 设计模式——抽象工厂模式及java实现

    设计模式--抽象工厂模式及java实现 设计模式在大型软件工程中很重要,软件工程中采用了优秀的设计模式有利于代码维护,方便日后更改和添加功能. 设计模式有很多,而且也随着时间在不断增多,其中最著名的是 ...

  2. 5. 星际争霸之php设计模式--抽象工厂模式

    题记==============================================================================本php设计模式专辑来源于博客(jymo ...

  3. iOS 设计模式之工厂模式

    iOS 设计模式之工厂模式 分类: 设计模式2014-02-10 18:05 11020人阅读 评论(2) 收藏 举报 ios设计模式 工厂模式我的理解是:他就是为了创建对象的 创建对象的时候,我们一 ...

  4. linkin大话设计模式--抽象工厂

    linkin大话设计模式--抽象工厂 在前面讲到的简单工厂里面虽然实现了我们那个类和其中的依赖的解耦,但是在产生我们需要的依赖的那个工厂里面还是和具体的产品类耦合了  现在要是还想彻底解耦的话怎么办呢 ...

  5. 设计模式——抽象工厂(Abstract Factory)

    Abstract Factory 抽象工厂模式(创建型模式): new的问题:实现依赖,不能应变应对“具体实例化类型”的变化. 解决思路:--封装变化点:哪里变化,封装哪里           - - ...

  6. JAVA设计模式--抽象工厂模式

    抽象工厂设计模式 1.系统中有多个产品族,而系统一次只可能消费其中一族产品2.同属于同一个产品族的产品以其使用.来看看抽象工厂模式的各个角色(和工厂方法的如出一辙):抽象工厂角色: 这是工厂方法模式的 ...

  7. 深入浅出设计模式——抽象工厂模式(Abstract Factory)

    模式动机在工厂方法模式中具体工厂负责生产具体的产品,每一个具体工厂对应一种具体产品,工厂方法也具有唯一性,一般情况下,一个具体工厂中只有一个工厂方法或者一组重载的工厂方法.但是有时候我们需要一个工厂可 ...

  8. C#设计模式——抽象工厂

    一.引言 我相信看到这段文字的人,都具备了良好的技术功底.但是对于自己编写的代码总是充满抱怨,希望能够将自己编写的代码如同房子一般先进行有效 的设计,然后在进行建设.那么这篇文章能够给你一些思路,这里 ...

  9. 24种设计模式--抽象工厂模式【Abstract Factory Pattern】

    女娲造人,人是造出来了,世界是热闹了,可是低头一看,都是清一色的类型,缺少关爱.仇恨.喜怒哀乐等情绪,人类的生命太平淡了,女娲一想,猛然一拍脑袋,忘记给人类定义性别了,那怎么办?抹掉重来,然后就把人类 ...

随机推荐

  1. AutoMapper用法一瞥

    前段时候做个小项目用到了autoMapper(参考了NOP里的用法),感觉还行,用起来挺方便的.首先复杂的东西我就不说了,至于详细的教程我也就不写了,比较园子里有很多这样的文章,我就分享下,在项目中实 ...

  2. [转载]AxureRP 7超强部件库下载

    很多刚刚开始学习Axure的朋友都喜欢到网上搜罗各种部件库(组件库)widgets library ,但是网络中真正实用的并且适合你使用的少之又少,最好的办法就是自己制作适合自己工作内容的部件库. 这 ...

  3. Xcode-快捷键大全

    1. 文件CMD + N: 新文件CMD + SHIFT + N: 新项目CMD + O: 打开CMD + S: 保存CMD+OPt+S:保存所有文件CMD + SHIFT + S: 另存为CMD + ...

  4. Android学习笔记之Drawable 文件夹

    PS:最近闲着无聊..模仿去写个QQapp..效果还不错..并且从中又学习到了一些相关的东西,在这里进行一些相关总结.. 学习内容: Android 中 Drawable 文件夹内部相关属性..   ...

  5. SQL Server 2012:SQL Server体系结构——一个查询的生命周期(第2部分)

    计划缓存(Plan Cache) 如果SQL Server已经找到一个好的方式去执行一段代码时,应该把它作为随后的请求重用,因为生成执行计划是耗费时间且资源密集的,这样做是有有意义的. 如果没找到被缓 ...

  6. python反射机制深入分析

    对编程语言比较熟悉的朋友,应该知道“反射”这个机制.Python作为一门动态语言,当然不会缺少这一重要功能.然而,在网络上却很少见到有详细或者深刻的剖析论文.下面结合一个web路由的实例来阐述pyth ...

  7. An Introduction to Garbage Collection(垃圾回收简介)

    1. Introduction 2. Principles 3. Advantages 4. Disadvantages 5. 常见的垃圾回收技术 5.1. 跟踪式垃圾回收 5.1.1. 基本算法 5 ...

  8. 图片轮播(左右切换)--JS原生和jQuery实现

    图片轮播(左右切换)--js原生和jquery实现 左右切换的做法基本步骤跟 上一篇文章  淡入淡出 类似,只不过修改了一些特定的部分 (1)首先是页面的结构部分 对于我这种左右切换式 1.首先是个外 ...

  9. 2015 Multi-University Training Contest 1 - 1009 Annoying problem

    Annoying problem Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=5296 Mean: 给你一个有根树和一个节点集合 ...

  10. 后缀数组 - 求最长回文子串 + 模板题 --- ural 1297

    1297. Palindrome Time Limit: 1.0 secondMemory Limit: 16 MB The “U.S. Robots” HQ has just received a ...