欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

iOS应用开发中运用设计模式中的组合模式的实例解析

程序员文章站 2023-11-20 17:01:10
何为组合模式?     组合模式让我们可以把相同基类型的对象组合到树状结构中,其中父节点包含同类型的子节点。换句话说,这种树状结构形成"部分...

何为组合模式?
    组合模式让我们可以把相同基类型的对象组合到树状结构中,其中父节点包含同类型的子节点。换句话说,这种树状结构形成"部分——整体"的层次结构。什么是“部分——整体”的层次结构呢?它是既包含对象的组合又包含叶节点的单个对象的一种层次结构。每个组合体包含的其他节点,可以是叶节点或者其他组合体。这种关系在这个层次结构中递归重复。因为每个组合或叶节点有相同的基类型,同样的操作可应用于它们中的每一个,而不必在客户端作类型检查。客户端对组合与叶节点进行操作时可忽略它们之间的差别。

    组合模式:将对象组合成树形结构以表示"部分——整体"的层次结构。组合使得用户对单个对象和组合对象的使用的具有一致性。

何时使用组合模式?

1.想获得对象抽象的树形表示(部分——整体层次结构);

2.想让客户端统一处理组合结构中的所有对象。

在cocoa touch框架中使用组合模式

    在cocoa touch框架中,uiview被组织成一个组合结构。每个uiview的实例可以包含uiview的其他实例,形成统一的树形结构。让客户端对单个uiview对象和uiview的组合统一对待。

    窗口中的uiview在内部形成它的子视图。它们的每一个可以包含其他视图而变成自己的子视图的超视图。添加进来的其他uiview成为它的子视图。它们的每一个可以包含其他视图而变成自己的子视图的超视图。uiview对象只能有一个超视图,可以有零到多个子视图。

    视图组合结构参与绘图事件处理。当请求超视图为显示进行渲染时,消息会先在超视图被处理,然后传给其子视图。消息会传播到遍及整个树的其他子视图。因为它们是相同的类型——uiview,它们可以被统一处理。

组合模式的实例引用

组合模式的适用场合是,一般当你发现需求中是体现部分与整体层次的结构时,以及你希望用户可以忽略组合对象与单个对象的不同,统一地使用组合结构中地所有对象时,就应该考虑使用组 合模式了。组合模式定义了基本对象和组合对象的类层次结构。基本对象可以被组合成更复杂的组合对象,而这个组合对象又可以被组合,这样不断地递归下去,这样,在客户代码中,任何使用到基本对象的地方都可以使用组合对象了。说了这么多,其实,组合模式就是让客户可以一致地使用组合结构和单个对象。那么,下面还是给出类结构图,想必大家一看就明白了。

iOS应用开发中运用设计模式中的组合模式的实例解析

上图中类之间的关系基本可以类比为一棵树的关系。有根(component)、有枝节点(composite)、有叶子节点(leaf)。逻辑很清晰,结构也比较简单。其实相当于叶子节点(leaf)和枝节点(composite)都继承自根节点(component)。好的,下面给出简单的代码实现。

注意:本文所有代码均在arc环境下编译通过。

comcomponents类接口 //对应图中的component

复制代码 代码如下:

#import <foundation/foundation.h>

@interface comcomponents:nsobject{
    nsstring *name;
}
-(comcomponents*)myinit:(nsstring*)myname;
-(void)add:(comcomponents*)c;
-(void)remove:(comcomponents*)c;
-(void)display:(int)depth;
@end


comcomponents类实现
复制代码 代码如下:

#import "comcomponents.h"

@implementation comcomponents

-(comcomponents*)myinit:(nsstring *)myname{
    name = myname;
    return self;
}
-(void)add:(comcomponents *)c{
    return;
}
-(void)remove:(comcomponents *)c{
    return;
}
-(void)display:(int)depth{
    return;
}
@end


leaf类接口
复制代码 代码如下:

#import "comcomponents.h"

@interface leaf:comcomponents
-(leaf*)myinit:(nsstring*)myname;
@end


leaf类实现
复制代码 代码如下:

#import "leaf.h"

@implementation leaf

-(leaf*)myinit:(nsstring *)myname{
    name = myname;
    return self;
}
-(void)add:(comcomponents *)c{
    nslog(@"cannot add to a leaf");
}
-(void)remove:(comcomponents *)c{
    nslog(@"cannot remove from a leaf");
}
-(void)display:(int)depth{
    nslog(@"[%dlevel]%@", depth,name);
}
@end


composite类接口
复制代码 代码如下:

#import "comcomponents.h"

@interface composite :comcomponents{
    nsmutablearray *children;
}
-(composite*)myinit:(nsstring*)myname;
@end


composite类实现
复制代码 代码如下:

#import "composite.h"

@implementation composite

-(composite*)myinit:(nsstring *)myname{
    name = myname;
    children= [nsmutablearray new];
    return self;
}
-(void)add:(comcomponents *)c{
    [children addobject:c];
}
-(void)remove:(comcomponents *)c{
    [children addobject:c];
}
-(void)display:(int)depth{
    nslog(@"[%dlevel]%@", depth,name);
    for(comcomponents *component in children)
        [component display:depth +1];
}
@end


main方法调用
复制代码 代码如下:

#import <foundation/foundation.h>
#import "leaf.h"
#import "composite.h"

int main (int argc,const char *argv[])
{
    @autoreleasepool{
        composite *root = [[composite alloc]myinit:@"root"];
        [root add:[[leaf alloc]myinit:@"leaf a"]];
        [root add:[[leaf alloc]myinit:@"leaf b"]];
        composite *comp = [[composite alloc]myinit:@"composite x"];
        [comp add:[[leaf alloc]myinit:@"leaf xa"]];
        [comp add:[[leaf alloc]myinit:@"leaf xb"]];
        [root add:comp];
        composite *comp2 = [[composite alloc]myinit:@"composite xy"];
        [comp2 add:[[leaf alloc]myinit:@"leaf xya"]];
        [comp2 add:[[leaf alloc]myinit:@"leaf xyb"]];
        [comp add:comp2];
        [root add:[[leaf alloc]myinit:@"leaf c"]];
        leaf *leaf = [[leaf alloc]myinit:@"leaf d"];
        [root add:leaf];
        [root remove:leaf];
        [root display:1];
    }
    return 0;
}


好啦,组合模式结构还算简单,关键还是活学活用啊,这个才是真难啊!