生成器

生成器,也成为建造者模式,同样是创建对象时的设计模式。该模式下有一个Director(指挥者),客户端知道该类引用用来创建产品。还有一个Builder(建造者),建造者知道具体创建对象的细节。

指挥者只是起到协调的作用,它有一个Builder引用用于指挥Builder如何创建对象,Builder内就是为了构建对象的算法。

其实生成器模式,就是为了定制某些特定对象而产生的模式。对象的过长往往非常的复杂,如果不是用该模式来创建对象,对象创建类将会非常的冗余且难以复用。使用生成器将表现层和创建层分离更加易于扩展和解耦。

使用场景

1.需要创建涉及各种部件的复杂对象。创建对象的算法应该独立于部件的装配方式。常见的例子是构建组合对象。

2.构建过程需要以不同的方式(例如,部件或表现的不同组合)构建对象。

生成器与抽象工厂对比

生成器

构建复杂对象

以多个步骤构建对象

在构建对象过程的最后一步返回产品

专注于一个特定产品

抽象工厂

构建简单或复杂对象

以单一步骤构建对象

以单一方式构建对象

立刻返回产品

强调一套产品

Demo

比如汽车制造厂需要制造两种不同的汽车:

首相创建Car类,有name和speed两个属性

#import <Foundation/Foundation.h>

@interface Car : NSObject

@property(nonatomic, strong)NSString *name;

@property(nonatomic ,assign)int speed;

@end

#import "Car.h"

@implementation Car

@end

创建Builder,Builder封装了创建类的具体细节

#import <Foundation/Foundation.h>
#import "Car.h" @interface CarBuilder : NSObject -(CarBuilder *)buildCar;
-(CarBuilder *)buildCarName;
-(CarBuilder *)buildCarSpeed;
-(Car *)getProduct; @end #import "CarBuilder.h" @implementation CarBuilder
{
Car *_product; }
-(CarBuilder *)buildCar
{
_product = nil;
_product = [Car new];
return self;
} -(CarBuilder *)buildCarName
{
_product.name = @"benz";
return self;
} -(CarBuilder *)buildCarSpeed
{
_product.speed = ;
return self;
} @end

具体的Builder类:

#import <Foundation/Foundation.h>
#import "CarBuilder.h" @interface CarBuilderBenz : CarBuilder @end #import "CarBuilderBenz.h" @implementation CarBuilderBenz
{
Car *_product;
} -(CarBuilder *)buildCar
{
_product = nil;
_product = [Car new];
return self;
} -(CarBuilder *)buildCarName
{
_product.name = @"benz";
return self;
} -(CarBuilder *)buildCarSpeed
{
_product.speed = ;
return self;
} -(Car *)getProduct
{
return _product;
} @end #import <Foundation/Foundation.h>
#import "CarBuilder.h"
@interface CarBuilderBMW : CarBuilder @end #import "CarBuilderBMW.h" @implementation CarBuilderBMW
{
Car *_product;
} -(CarBuilder *)buildCar
{
_product = nil;
_product = [Car new];
return self;
} -(CarBuilder *)buildCarName
{
_product.name = @"BMW";
return self;
} -(CarBuilder *)buildCarSpeed
{
_product.speed = ;
return self;
} -(Car *)getProduct
{
return _product;
}
@end

Director类,Director知道生产产品,但并不知道具体生产细节。

#import <Foundation/Foundation.h>
#import "CarBuilder.h"
#import "Car.h" @interface CarDirector : NSObject -(Car *)createCarBenz:(CarBuilder *)builder;
-(Car *)createCarBMW:(CarBuilder *)builder; @end #import "CarDirector.h" @implementation CarDirector -(Car *)createCarBenz:(CarBuilder *)builder
{
[builder buildCar];
[builder buildCarName];
[builder buildCarSpeed];
return [builder getProduct];
} -(Car *)createCarBMW:(CarBuilder *)builder
{
[builder buildCar];
[builder buildCarName];
[builder buildCarSpeed];
return [builder getProduct];
} @end

客户端代码:

        CarDirector *director = [CarDirector new];
CarBuilderBenz *benzBuilder = [CarBuilderBenz new];
CarBuilderBMW *BMWBuilder = [CarBuilderBMW new];
Car *benz = [director createCarBenz:benzBuilder];
Car *bmw = [director createCarBMW:BMWBuilder];
NSLog(@"benz: name = %@ ,speed = %d",benz.name ,benz.speed);
NSLog(@"BMW: name = %@ ,speed = %d",bmw.name ,bmw.speed);

结果:

-- ::04.298 Builder[:] benz: name = benz ,speed =
-- ::04.298 Builder[:] BMW: name = BMW ,speed =

可以看到,不同的builder封装不同的创建对象逻辑,产生不同的对象,同时分离了创建层和表示层。

Objective-C设计模式——生成器Builder(对象创建)的更多相关文章

  1. Builder(生成器)-对象创建型模式

    一.意图 将一个复杂对象的构建与它的表示分离,使得同样的构造过程可以创建不同的表示. 二.动机 一个复杂的对象的构造过程中,原料相同,可能会要求生产不同的产品,并且生产的产品种类还能够方便的增加.Bu ...

  2. 设计模式---对象创建模式之构建器模式(Builder)

    一:概念 Builder模式也叫建造者模式或者生成器模式,是由GoF提出的23种设计模式中的一种.Builder模式是一种对象创建型模式之一,用来隐藏复合对象的创建过程,它把复合对象的创建过程加以抽象 ...

  3. 设计模式03: Builder 生成器模式(创建型模式)

    Builder生成器模式(创建型模式) Builder模式缘起假设创建游戏中的一个房屋House设施,该房屋的构建由几个部分组成,且各个部分富于变化.如果使用最直观的设计方法,每个房屋部分的变化,都将 ...

  4. 跟着实例学习设计模式(6)-生成器模式builder(创建型)

    生成器模式是创建型设计模式. 设计意图:将一个复杂的类表示与其构造相分离,使得同样的构建过程可以得出不同的表示. 实例类图: IVehicleBuilder:抽象建造者.为创建一个Vehicle对象并 ...

  5. C++设计模式 之 “对象创建”模式:Factory Method、Abstract Factory、Prototype、Builder

    part 0 “对象创建”模式 通过“对象创建” 模式绕开new,来避免对象创建(new)过程中所导致的紧耦合(依赖具体类),从而支持对象创建的稳定.它是接口抽象之后的第一步工作. 典型模式 Fact ...

  6. 23种设计模式 - 对象创建(FactoryMethod - AbstractFactory - Prototype - Builder)

    其他设计模式 23种设计模式(C++) 每一种都有对应理解的相关代码示例 → Git原码 ⌨ 对象创建 通过"对象创建" 模式绕开new,来避免对象创建(new)过程中所导致的紧耦 ...

  7. 设计模式之生成器(Builder)模式

    意图 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以表示不同的表示. 适用性 当创建复杂对象的算法应该独立于该对象的组成部分以及它们的装配方式时. 当构造过程必须允许被构造的对象有不同的表 ...

  8. C#设计模式——生成器模式(Builder Pattern)

    一.概述在软件系统中,有时候面临着复杂的对象创建,该对象由一定算法构成的子对象组成,由于需求变化,这些子对象会经常变换,但组合在一起的算法却是稳定的.生成器模式可以处理这类对象的构建,它提供了一种封装 ...

  9. 【转】设计模式(三)建造者模式Builder(创建型)

    (http://blog.csdn.net/hguisu/article/details/7518060) 1. 概述 在软件开发的过程中,当遇到一个"复杂的对象"的创建工作,该对 ...

随机推荐

  1. hibernate dynamic-update="true"属性不起作用原因(转载)

    原文地址: https://yan-sa.iteye.com/blog/1913684 由于我在action层使用了注解多例@Scope("prototype"),而在dao层默认 ...

  2. HDD

    硬盘 SCSI ★ Host adapter ★ SCSI standard ★ Bus socket ★ Signal fashion ★ SCAM ★ Bus main control ★ Dri ...

  3. Centos6.4安装Zimbra初步教程

    环境: 1.centos6.4*64位版本 2.主机最好内存设置在2G以上,要不安装的时候卡死你 3.下载最新的开源的Zimbra安装包,下载zcs-8.0.4_GA_5737.RHEL6_64.20 ...

  4. Vmware worksiation中使用ISO

    Vmware技巧: 用ISO安装系统,需要添加2个CD设备. IDE 1  中选择 autoinst.iso IDE 2  中选择 “要安装的系统”.iso 简单讲:Vmware模拟机上需要模拟两次i ...

  5. js算法:分治法-循环赛事日程表

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...

  6. Cacti监控Redis实现过程

    Cacti是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监測图形分析工具.被广泛的用于对server的运维监控中,Cacti提供了一种插件式的管理.仅仅要按要求写好特定的模板,那 ...

  7. tensorflow,torch tips

    apply weightDecay,L2 REGULARIZATION_LOSSES weights = tf.get_collection(tf.GraphKeys.TRAINABLE_VARIAB ...

  8. DSPC6748中某问题的解决方式

    因为之前没有做过DSP相关的开发,属于菜鸟中的菜鸟.出现故障后.不知道从哪方面来解决这些小问题. 开发环境:CCS5.5.0 开发板:TI公司的TMS320C6748 问题: 控制台出现初始化结束后多 ...

  9. [办公自动化]excel工作簿内的表无法删除,单击右键无删除键

    今天同事问,我自己的工作簿,没有设置保护,但是就是无法删除其中的工作表. 后来发现,她的excel工作簿打开的文件名后面显示[共享]. 原因找到了. 取消共享就可以了.

  10. 稀疏表达是要求信号在该模型下的sparse code,只有少数的non-zero elements

    为什么sparse representation比起其它成分分析方法(DFT,Wavelet)能得到更好的效果? - 知乎  https://www.zhihu.com/question/241241 ...