鍍金池/ 教程/ C/ Objective-C 復合對象
Objective-C 多態(tài)性
Objective-C 預處理器
Objective-C for循環(huán)
Objective-C 開發(fā)環(huán)境(安裝配置)
Obj-C Foundation/基礎框架
Objective-C 指針運算
Objective-C 循環(huán)
Objective-C 錯誤處理
Objective-C while循環(huán)
Objective-C if語句
Objective-C do...while循環(huán)
Objective-C教程
Objective-C 嵌套switch語句
Objective-C 函數(shù)按值調(diào)用
Objective-C 常量
Objective-C 運算符
Objective-C 數(shù)據(jù)類型
Objective-C 邏輯運算符
Objective-C 數(shù)組作為函數(shù)參數(shù)傳遞
Objective-C struct/結(jié)構(gòu)
Objective-C 嵌套循環(huán)
Objective-C 函數(shù)引用調(diào)用
Objective-C 日志處理
Objective-C 數(shù)據(jù)存儲
Objective-C 教程首頁
Objective-C 擴展
Objective-C 異常處理
Objective-C 類型轉(zhuǎn)換
Objective-C 嵌套 if 語句
Objective-C typedef
Objective-C 決策
Objective-C 指針的數(shù)組
Objective-C Protocols/協(xié)議
Objective-C 日期和時間
Objective-C 指針
Objective-C 內(nèi)存管理
命令行參數(shù)
Objective-C NSString/字符串
Objective-C 動態(tài)綁定
Objective-C 復合對象
Objective-C Arrays/數(shù)組
Objective-C 位運算符
Objective-C 指向指針的指針
Objective-C 從函數(shù)返回數(shù)組
Objective-C Posing/冒充
Objective-C Categories/類別
Objective-C 文件處理
Objective-C 賦值運算符
Objective-C 函數(shù)返回指針
Objective-C if...else 語句
Objective-C switch語句
Objective-C URL加載系統(tǒng)
Objective-C 算術(shù)運算符
Objective-C Numbers/數(shù)字
Objective-C語言程序結(jié)構(gòu)
Objective-C 快速枚舉
Objective-C 基本語法
Objective-C 類&對象
Objective-C 變量
Objective-C 關系運算符
Objective-C 塊
Objective-C break語句
Objective-C continue語句
Objective-C 語言概述
Objective C 文本和字符串
Objective-C 函數(shù)
Objective-C 傳遞函數(shù)的指針
Objective-C 數(shù)組的指針
Objective-C 多維數(shù)組
Objective-C 繼承
Objective-C 數(shù)據(jù)封裝

Objective-C 復合對象

我們可以創(chuàng)建子類簇內(nèi)嵌入對象定義了一個類。這些類對象是復合對象。

所以,你可能會想知道什么是類簇。所以我們會先看看什么是類簇。

類簇

類簇是Foundation框架的設計模式,使用了大量的。類簇群的一些私有的具體子類下一個公共的抽象父類。在這樣的類分組,簡化公開可見的一個面向?qū)ο蟮目蚣芙Y(jié)構(gòu),而不降低其功能豐富。類集群的基礎上抽象工廠設計模式。

為了簡單,而不是創(chuàng)建多個類似函數(shù)的類,我們創(chuàng)建了一個類,其處理的基礎上處理輸入的值。

例如,在 NSNumber有許多簇類,如字符型,整型,布爾等。我們組合所有這些到一個單一的,負責處理類似的操作在一個類中的類。NSNumber 實際上這些原始類型到對象封裝的值。

那么什么是完全相同復合對象?

私有集群對象嵌入在我們自己設計的對象,我們創(chuàng)建一個復合對象。這種復合對象可以依靠其基本功能的群集對象,只攔截消息,希望在某些特定的方式處理復合對象。這種結(jié)構(gòu)減少了我們必須編寫的代碼量,可利用基礎框架所提供的測試代碼。

下圖對此進行了解釋。

Objective-C Composite Objects

復合對象必須聲明自己是一個集群的抽象父類的子類。作為一個子類,它必須覆蓋父類的原始方法。它也可以重寫派生的方法,但這不是必需的,因為派生的方法通過原語工作。

NSArray類的計數(shù)方法是一個例子,它覆蓋的方法可以干預對象的實現(xiàn)也很簡單,如:

- (unsigned)count 
{
return [embeddedObject count];
}

在上面的例子中,嵌入的對象實際上是類型的NSArray。

一個復合對象的例子

現(xiàn)在,為了看到一個完整的例子,讓我們來看看下面給出的例子來自蘋果的文檔。

#import <Foundation/Foundation.h>

@interface ValidatingArray : NSMutableArray
{
    NSMutableArray *embeddedArray;
}

+ validatingArray;
- init;
- (unsigned)count;
- objectAtIndex:(unsigned)index;
- (void)addObject:object;
- (void)replaceObjectAtIndex:(unsigned)index withObject:object;
- (void)removeLastObject;
- (void)insertObject:object atIndex:(unsigned)index;
- (void)removeObjectAtIndex:(unsigned)index;

@end

@implementation ValidatingArray
- init
{
   self = [super init];
   if (self) {
      embeddedArray = [[NSMutableArray allocWithZone:[self zone]] init];
   }
   return self;
}

+ validatingArray
{
   return [[self alloc] init] ;
}
- (unsigned)count
{
   return [embeddedArray count];
}
- objectAtIndex:(unsigned)index
{
    return [embeddedArray objectAtIndex:index];
}
- (void)addObject:(id)object
{
   if (object != nil) {
      [embeddedArray addObject:object];
   }
}
- (void)replaceObjectAtIndex:(unsigned)index withObject:(id)object;
{
   if (index <[embeddedArray count] && object != nil) {
       [embeddedArray replaceObjectAtIndex:index withObject:object];
   }
}
- (void)removeLastObject;
{
   if ([embeddedArray count] > 0) {
       [embeddedArray removeLastObject];
   }
}
- (void)insertObject:(id)object atIndex:(unsigned)index;
{
   if (object != nil) {
       [embeddedArray insertObject:object atIndex:index];
   }
}
- (void)removeObjectAtIndex:(unsigned)index;
上一篇:Objective-C 算術(shù)運算符下一篇:Objective-C 從函數(shù)返回數(shù)組