为什么 “简单工厂原理” 叫简单工厂,因为这个工厂类不是抽象类,而是实体类,工厂本身就是一个具体的对象。

写一个例子演示简单工厂模式:

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
协议的用法,小何子总结:
一个类如果实现了某个协议,这个协议中的方法就可以直接在这个类的@implementation中实现
注意:协议中的方法不需要在这个类@interface中声明出来

接着,继承实现协议的类的子类,协议中得方法同样不需要在@interface中声明,
        但需要哪个协议里的方法的话就在@implementation中实现。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

手机协议,提供了所有手机的共同的功能。
记住:使用协议的目的,是为了能统一使用的接口,也是为了客户端使用是要遵循某项协议的。
PhoneProtocol.h:

 #import <Foundation/Foundation.h>

 @protocol PhoneProtocol <NSObject>

 @required

 /**
* 打电话
*/
- (void)phoneCall; /**
* 发短信
*/
- (void)sendMessage; @end

=====================================================
基本的手机设备,抽象类,具备手机的基本的功能,
    接收一个协议并继承必须要的功能:打电话和发短信
BaseDevie.h:

 #import <Foundation/Foundation.h>
#import "PhoneProtocol.h" @interface BaseDevie : NSObject <PhoneProtocol> @end

BaseDevie.m:

 #import "BaseDevie.h"

 @implementation BaseDevie

 - (void)phoneCall {
} - (void)sendMessage {
} @end

=====================================================
DeviceFactory.h:

 #import <Foundation/Foundation.h>
#import "BaseDevie.h"
#import "iPhoneDevice.h"
#import "AndroidDevice.h"
#import "NokiaDevice.h" typedef enum : NSUInteger { kiPhone = 0x11,
kAndroid,
kNokia, } EDevieType;
简单工厂模式的工厂类,是根据客户端的某条指令来生产具体某个设备,这里就通过枚举列举出用户的具体相关的指令。
总结:工厂模式经常可以和枚举搭配,因为工厂模式生成基本行为相同拓展行为不同的同一类对象
这些不同但基础本质相容的对象,可以用枚举列举。
例如:这里就用枚举列举了:iPhone、Android、Nokia三种手机。
枚举的名字EDevieType的开头是个习惯用法用E。
@interface DeviceFactory : NSObject //首先,这个工厂类会返回一个对象,什么样的对象呢?这个对象本身就是实现了接口PhoneProtocol的对象
/**
* 根据用户提交的指令创建出具体的手机
*
* @param type 创建的指令
*
* @return 创建出的手机
*/
+ (BaseDevie <PhoneProtocol> *)deviceFactoryWithDevieType:(EDevieType)type; @end

DeviceFactory.m:

 #import "DeviceFactory.h"

 @implementation DeviceFactory

 + (BaseDevie <PhoneProtocol> *)deviceFactoryWithDevieType:(EDevieType)type {

     BaseDevie <PhoneProtocol> *device = nil;//使用实现协议的类,声明指针对象的时候记得带上<协议>

     if (type == kiPhone) {

         device = [[iPhoneDevice alloc] init];

     }  else if (type == kAndroid) {

         device = [[AndroidDevice alloc] init];

     }  else if (type == kNokia) {

         device = [[NokiaDevice alloc] init];

     }

     return device;
} @end

=====================================================
iPhoneDevice.h:

 #import "BaseDevie.h"

 @interface iPhoneDevice : BaseDevie

 /**
* 指纹识别
* 多的一个功能,也是iPhone自己独有的功能。也是区别同类产品的关键。
* 特有的功能就可以在自己的@interface中实现。
*/
- (void)fingerprintIndetification; @end

iPhoneDevice.m:

 #import "iPhoneDevice.h"

 @implementation iPhoneDevice
因为继承自实现了协议的BaseDevie,所以这里只需要在implementation实现协议里的方法就可以了。
- (void)phoneCall { NSLog(@"iPhone phoneCall");
} - (void)sendMessage { NSLog(@"iPhone sendMessage");
} - (void)fingerprintIndetification { NSLog(@"iPhone fingerprintIndetification");
} @end

=====================================================
AndroidDevice.h:

 #import "BaseDevie.h"

 @interface AndroidDevice : BaseDevie

 /**
* 定制主题
*/
- (void)customTheme; @end

AndroidDevice.m:

 #import "AndroidDevice.h"

 @implementation AndroidDevice

 - (void)phoneCall {

     NSLog(@"Android phoneCall");
} - (void)sendMessage { NSLog(@"Android sendMessage");
} - (void)customTheme { NSLog(@"Android customTheme");
} @end

=====================================================
NokiaDevice.h:

 #import "BaseDevie.h"

 @interface NokiaDevice : BaseDevie

 /**
* 敲核桃
*/
- (void)knockWalnut; @end

NokiaDevice.m:

 #import "NokiaDevice.h"

 @implementation NokiaDevice

 - (void)phoneCall {

     NSLog(@"Nokia phoneCall");
} - (void)sendMessage { NSLog(@"Nokia sendMessage");
} - (void)knockWalnut { NSLog(@"Nokia knockWalnut");
} @end

==============================================================

客户端只有ViewController.m中:

 #import "ViewController.h"
#import "DeviceFactory.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // 工厂中创建出具体产品
iPhoneDevice *iPhone = (iPhoneDevice *)[DeviceFactory deviceFactoryWithDevieType:kiPhone]; // 使用产品的特有的功能
[iPhone fingerprintIndetification]; //如果工厂中创建出具体产品,是这样的:
//BaseDevie *iPhone = [DeviceFactory deviceFactoryWithDevieType:kiPhone];
//这样的话,手机就不能使用自己特有的功能,也就是不能使用自己类的@interface中声明的方法
} @end

简单工厂:工厂类通过客户端发送一个指令产生具体的产品,而这些产品彼此之间都有共同的特性,共同的特性由协议规定了,但是具体的产品对象有自己特有的功能,就需要具体的声明和实现。这就是简单工厂。

那么简单工厂的使用场景
1. 简化生产流程
    客户只关心最终产品,所以可以把具体生产流程封装起来,通过简单工厂创建最终产品。所以起到了简化生产流程。
2. 隔离生产产品的细节
    前面一点提到了。
3. 不同类型的产品之间有着一些共同的功能
    共同的功能可以通过协议来设定和规划。
4. 一个具体的工厂
    是直接实现的工厂,而不是某个通过继承或者抽象的方法来实现生产的需求。

源码下载链接:http://pan.baidu.com/s/1bnynlQf 密码:ss43

 

IOS设计模式-简单工厂的更多相关文章

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

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

  2. 3. 星际争霸之php设计模式--简单工厂模式

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

  3. java设计模式--简单工厂

    java设计模式--简单工厂 简单工厂不是一个标准的设计模式,但是很常用需要掌握. 在java应用开发中,要"面向接口编程". 1.java中接口的概念: 在java中接口是一种特 ...

  4. Golang设计模式—简单工厂模式(Simple Factory Pattern)

    Golang设计模式--简单工厂模式 背景 假设我们在做一款小型翻译软件,软件可以将德语.英语.日语都翻译成目标中文,并显示在前端. 思路 我们会有三个具体的语言翻译结构体,或许以后还有更多,但现在分 ...

  5. iOS开发-简单工厂模式

    设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性.概念很长,iOS开发中最常 ...

  6. C++设计模式——简单工厂模式

    简单工厂模式(Simple Factory Pattern) 介绍:简单工厂模式不能说是一个设计模式,说它是一种编程习惯可能更恰当些.因为它至少不是Gof23种设计模式之一.但它在实际的编程中经常被用 ...

  7. java设计模式--简单工厂模式

     简单工厂设计模式 工厂模式就是专门负责将大量有共同接口的类实例化,而且不必事先知道每次是要实例化哪一个类的模式.它定义一个用于创建对象的接口,由子类决定实例化哪一个类. 核心知识点如下: (1) 大 ...

  8. C#设计模式-简单工厂

    工厂模式专门负责将大量有共同接口的类实例化.工厂模式可以动态决定将哪一个类实例化,不必事先知道每次要实例化哪一个类.工厂模式有以下几种形态: 简单工厂(Simple Factory)模式 工厂方法(F ...

  9. 深入浅出设计模式——简单工厂模式(Simple Factory)

    介绍简单工厂模式不能说是一个设计模式,说它是一种编程习惯可能更恰当些.因为它至少不是Gof23种设计模式之一.但它在实际的编程中经常被用到,而且思想也非常简单,可以说是工厂方法模式的一个引导,所以我想 ...

随机推荐

  1. python BDD 框架之lettuce

    http://pythonhosted.org/lettuce/ 介绍                                                                 ...

  2. VirtualBox的网络设置(6种方式)

    VirtualBox 可以为每一个虚拟机分配8个网卡.每一个网卡的连接方式可以选为下列之一: Not attached Network Address Translation (NAT) Bridge ...

  3. Sylius – 100% 免费和开源的电子商务解决方案

    Sylius 项目提供了一个完整的电子商务解决方案.您将学习如何掌握它,帮助你在下一个项目中能够更快速的开发.Sylius 提供了一个完整的在线商店演示:demo.sylius.com. 您可能感兴趣 ...

  4. Zookeeper集群部署

    一. 部署前的准备工作 保证各个主机之间能够正常通信,最好是在同一网段. 修改host文件,加入IP和主机名的映射.方法为修改/etc/hosts和etc/hostname文件,不同的Linux发行版 ...

  5. 浅谈WeakHashMap

    Java WeakHashMap 到底Weak在哪里,它真的很弱吗?WeakHashMap 的适用场景是什么,使用时需要注意些什么?弱引用和强引用对Java GC有什么不同影响?本文将给出清晰而简洁的 ...

  6. 重构第25天 引入契约设计(Introduce Design By Contract checks)

    理解:本文中的”引入契约式设计”是指我们应该对应该对输入和输出进行验证,以确保系统不会出现我们所想象不到的异常和得不到我们想要的结果. 详解:契约式设计规定方法应该对输入和输出进行验证,这样你便可以保 ...

  7. WPF 竖排文字

    ---恢复内容开始--- 想做一个WPF 文字竖排 类似上图.用在TabItem的header上面. <TextBlock FontSize="30" Text=" ...

  8. 记录一款不错的插件fullpage.js

    下载链接包括一些实例: http://www.dowebok.com/demo/2014/77/ 当然也可以从Github 上下载: https://github.com/alvarotrigo/fu ...

  9. sql2008 查询字段所属表

    select a.name as 表名, g.*from sysobjects as a left join syscolumns as b on a.id=b.id left JOIN sys.ex ...

  10. JavaMail入门第三篇 发送邮件

    JavaMail API中定义了一个java.mail.Transport类,它专门用于执行邮件发送任务,这个类的实例对象封装了某种邮件发送协议的底层实施细节,应用程序调用这个类中的方法就可以把Mes ...