生成器模式的学习

生成器模式的学习

前言

以前如果一个对象有多个参数我在构建的时候总会写一个完全初始化方法类似的东西,最近在看<<高性能iOS应用开发>>这本书,发现生成器模式这种利用子系统生成对象的方式也很取巧,下面来介绍一下吧.

例如一个需求,要求构造这个对象,它具有,,年龄等属性,那我们如何在考虑扩展以及减少对外界的影响上对他设计呢?先来看看一般操作怎么来吧.

完全初始化模式

- (instancetype)initWithFirstname:(NSString *)firstName lastName:(NSString *)lastName age:(NSInteger)age;

其实能满足需求,也能对数据做一些过滤什么的操作,但是如果我们以后对Person这个对象的属性进行扩展,那么势必要更改公有的api,这是一件非常麻烦的事情,而且方法名也会变长,十分的令人头痛.但相对的也会有好处,例如公共方法名改变的时候,编译器就会编译不通过,对开发者进行提示说这里需要更新.

生成器模式

源代码地址

Person类的头文件

#import <Foundation/Foundation.h>
#import "PersonBuilder.h"

@interface Person : NSObject

//这里可以对属性进行一些设置,例如只读等等
@property (copy, nonatomic) NSString *firstName;
@property (copy, nonatomic) NSString *lastName;
@property (assign, nonatomic) NSInteger age;

+ (instancetype)personWithBlock:(void (^)(PersonBuilder *))block;
- (instancetype)initWithBuilder:(PersonBuilder *)builder;

@end

Person类的实现文件

#import "Person.h"
#define FY_SAFE_BLOCK(BlockName, ...) ({ !BlockName ? nil : BlockName(__VA_ARGS__); })
@implementation Person

- (instancetype)initWithBuilder:(PersonBuilder *)builder{
    if (self = [super init]) {
        //这里可以对数据做一些过滤以及线程安全的操作
        self.firstName = builder.firstName;
        self.lastName = builder.lastName;
        self.age = builder.age;
    }
    return self;
}

+ (instancetype)personWithBlock:(void (^)(PersonBuilder *))block{
    PersonBuilder *builder = [[PersonBuilder alloc] init];
    //外部对生成器进行设置
    FY_SAFE_BLOCK(block,builder);
    return [builder build];
}
@end

PersonBuilder的头文件

#import <Foundation/Foundation.h>

@class Person;
@interface PersonBuilder : NSObject

@property (copy, nonatomic) NSString *firstName;
@property (copy, nonatomic) NSString *lastName;
@property (assign, nonatomic) NSInteger age;

- (Person *)build;
@end

PersonBuilder的实现文件

#import "PersonBuilder.h"
#import "Person.h"

@implementation PersonBuilder

- (Person *)build{
    return [[Person alloc] initWithBuilder:self];
}
@end

构造方式

    Person *personA = [Person personWithBlock:^(PersonBuilder *builder) {
        builder.firstName = @"明";
        builder.lastName = @"李";
        builder.age = 18;
    }];

这种生成器模式的优点就是可以向下兼容,兼容过去生成的对象,同时可以对这些旧对象做一些操作,例如对Person的缺省对象在构造器里进行对builder的判断,若为空则可以设置一个默认值上去,当然这也是缺点吧,我们如果像全聚德更改也并非易事

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,958评论 19 139
  • 1 场景问题# 1.1 继续导出数据的应用框架## 在讨论工厂方法模式的时候,提到了一个导出数据的应用框架。 对于...
    七寸知架构阅读 5,872评论 1 64
  • Scala与Java的关系 Scala与Java的关系是非常紧密的!! 因为Scala是基于Java虚拟机,也就是...
    灯火gg阅读 3,487评论 1 24
  • 我 突然想起你 想起你趴在桌边半睡微醒时淡淡满足的脸庞,想起你站在阳光下暖风吹乱肆无忌惮的笑声,想起你终日在我梦里...
    半杯抹茶jiang阅读 298评论 2 2
  • 真实的事物最大的特点是:永恒存在,无关时间,无关观察者,无关角度,无关对象,真实是规律,无论你是否承认它,不管到底...
    huangxiaoliyy阅读 257评论 0 1