Objective C--模板方法模式


  今天和大家分享的是模板方法模式。这个模式的核心思想就是通过把不变的行为搬移到超类,去除子类中的重复代码来体现它的优势。其实,模板方法模式就是提供了一个很好的代码复用平台。

  首先,还是先简单看一下定义:

  模板方法模式,定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。

  下面和给大家展示一下类的结构图:


  其实,结构很简单,只有两层关系,核心思想就是把公共方法向上提到父类中。代码实现起来也不复杂。下面还是老样子,向大家简单展示一下代码如何实现。

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

  • AbstractClass类接口

1
2
3
4
5
6
7
#import <Foundation/Foundation.h>
                       
@interface AbstractClass : NSObject
-( void )PrimitiveOperation1;
-( void )PrimitiveOperation2;
-( void )TemplateMethod;
@end
  • AbstractClass类实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#import "AbstractClass.h"
    
@implementation AbstractClass
-( void )PrimitiveOperation1{
    return ;
}
-( void )PrimitiveOperation2{
    return ;
}
-( void )TemplateMethod{
    [ self PrimitiveOperation1];
    [ self PrimitiveOperation2];
    return ;
}
@end

 

  • ConcreteClassA类接口

1
2
3
4
#import "AbstractClass.h"
                 
@interface ConcreteClassA:AbstractClass
@end
  • ConcreteClassA类实现

1
2
3
4
5
6
7
8
9
10
#import "ConcreteClassA.h"
               
@implementation ConcreteClassA
-( void )PrimitiveOperation1{
    NSLog (@ "具体类A方法1实现" );
}
-( void )PrimitiveOperation2{
    NSLog (@ "具体类A方法2实现" );
}
@end
  • ConcreteClassB类接口

1
2
3
4
#import "AbstractClass.h"
             
@interface ConcreteClassB:AbstractClass
@end
  • ConcreteClassB类实现

1
2
3
4
5
6
7
8
9
10
#import "ConcreteClassB.h"
           
@implementation ConcreteClassB
-( void )PrimitiveOperation1{
   NSLog (@ "具体类B方法1实现" );
}
-( void )PrimitiveOperation2{
   NSLog (@ "具体类B方法2实现" );
}
@end
  • Main方法调用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#import <Foundation/Foundation.h>
#import "ConcreteClassA.h"
#import "ConcreteClassB.h"
        
int main ( int argc, const char * argv[])
{
    @autoreleasepool {
        AbstractClass *c = [[ConcreteClassA alloc]init];
        [c TemplateMethod];
        c = [[ConcreteClassB alloc]init];
        [c TemplateMethod];
    }
return 0;
}

  代码展示完毕!其实,模板方法模式就是提供了一个很好的代码复用平台,当不变的和可变的行为在方法的子类实现中混合在一起的时候,不变的行为就会在子类中重复出现。我们通过模板方法模式把这些行为搬移到单一的地方,这样就帮助子类摆脱重复的不变行为的纠缠。

  看起来不难,不过关键还是活学活用啊,呵呵!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Objective-C 的委托模式是一种常用的设计模式,它用于将对象之间的通信解耦。在委托模式中,一个对象(称为委托方)将某些行为委托给另一个对象(称为代理方)来处理。 在 Objective-C 中,委托模式通常使用协议来实现。委托方定义一个协议,并声明一些必需或可选的方法,代理方实现这些方法来处理委托方所委托的行为。委托方可以将自身作为参数传递给代理方,以便代理方在处理这些行为时可以与委托方进行通信。 下面是一个简单的委托模式示例,其中定义了一个协议 `MyDelegate`,并通过委托将行为委托给另一个对象 `MyClass`: ``` @protocol MyDelegate - (void)doSomething; @end @interface MyClass : NSObject @property (nonatomic, weak) id<MyDelegate> delegate; - (void)start; @end @implementation MyClass - (void)start { // 委托方调用代理方实现的方法 [self.delegate doSomething]; } @end ``` 在上面的示例中,`MyClass` 定义了一个属性 `delegate`,用于保存代理方的实例。在 `start` 方法中,委托方调用代理方实现的 `doSomething` 方法。 现在假设我们有一个对象 `MyDelegateObject`,它实现了 `MyDelegate` 协议中的 `doSomething` 方法: ``` @interface MyDelegateObject : NSObject<MyDelegate> @end @implementation MyDelegateObject - (void)doSomething { NSLog(@"Do something..."); } @end ``` 我们可以将 `MyDelegateObject` 实例作为 `MyClass` 的代理,并启动 `MyClass` 实例来执行委托: ``` MyClass *myClass = [[MyClass alloc] init]; MyDelegateObject *delegateObject = [[MyDelegateObject alloc] init]; myClass.delegate = delegateObject; [myClass start]; ``` 在上面的代码中,我们创建了一个 `MyClass` 实例和一个 `MyDelegateObject` 实例,并将 `delegateObject` 设置为 `myClass` 的代理。当 `start` 方法被调用时,`MyDelegateObject` 实例的 `doSomething` 方法将被执行,输出日志 "Do something..."。 通过委托模式,我们可以将对象之间的通信解耦,并使对象之间的关系更加灵活。委托模式在 iOS 开发中有很多应用,例如 UITableView 和 UICollectionView 的委托。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值