举例讲解设计模式中的原型模式在iOS应用开发中的作用

2020-01-15 13:29:51于海丽


最为关键的是Player需要实现NSCopying协议:
复制代码
#pragma mark - Override
- (instancetype)copyWithZone:(NSZone *)zone
{
    Player *copyPlayer = [[[self class] allocWithZone:zone] init];
    copyPlayer.highestLevel = self.highestLevel;
    copyPlayer.currentLevel = self.currentLevel;

 

    return copyPlayer;
}


这里大家看到NSZone类型, 这是个什么类型呢? 其实它是一个结构体, 是为了防止内存碎片化而引入的一个结构. NSZone会根据你想要开辟的内存大小来分配内存, 提高内存管理. 然而官方的Programming with ARC Release Note也指出, 目前的runtime系统忽略了区域的概念,因为本身的内存管理已经非常有效率,使用Zone反而会降低内存使用,访问效率, 增加源代码复杂度等.所以一般不使用NSZone, 而在这个例子中, 虽说使用了allocWithZone的方法, 但是我们进去看源代码则会发现: Apple其实还是用一般的初始化方法代替了原来的Zone开辟:
复制代码
#pragma mark - Override
- (instancetype)copyWithZone:(NSZone *)zone
+ (instancetype)allocWithZone:(struct _NSZone *)zone OBJC_SWIFT_UNAVAILABLE("use object         
  initializers instead");
原型设计模式基本就是这些, 当然我们的Player类可以变成一个接口, 让子类去实现, 更好的体现面向接口编程.

 

结果:


2015-09-18 21:30:32.072 DP_Prototype[1173:280693] <Player: 0x14d513f60>
2015-09-18 21:30:32.073 DP_Prototype[1173:280693] <Player: 0x14d5337e0>

在其他文件调用copy方法, 即可看到系统为我们新开辟的一块内存, 引用计数为1.

4.Cocoa Touch框架中的对象复制
CocoaTouch框架为NSObject的派生类提供了实现深复制的协议。NSObject的子类需要实现NSCopying协议及其方法--(id)copyWithZone:(NSZone *)zone。NSObject有一个实例方法叫做(id)copy。默认的copy方法调用[selfcopyWithZone:nil]。对于采纳了NSCopying协议的子类,需要实现这个方法,否则将引发异常。IOS中,这个方法保持新的副本对象,然后将其返回。此方法的调用者需要负责释放返回的对象。
深复制的技巧在于:保证确实复制了内存中的资源,而不只是指指针。



注:相关教程知识阅读请移步到IOS开发频道。