उद्देश्य-सी समग्र वस्तुएं

हम एक वर्ग क्लस्टर के भीतर उपवर्ग बना सकते हैं जो एक वर्ग को परिभाषित करता है जो उसके भीतर एक वस्तु को एम्बेड करता है। ये वर्ग वस्तुएँ संयुक्त वस्तुएँ हैं। तो आप सोच रहे होंगे कि क्लास क्लस्टर क्या है। इसलिए हम पहले देखेंगे कि क्लास क्लस्टर क्या है।

क्लास क्लस्टर्स

क्लास क्लस्टर एक डिज़ाइन पैटर्न है जिसका आधार फ्रेमवर्क व्यापक उपयोग करता है। क्लास क्लस्टर एक सार्वजनिक अमूर्त सुपरक्लास के तहत कई निजी ठोस उपवर्गों का समूह बनाते हैं। इस तरह से कक्षाओं का समूहन किसी वस्तु-उन्मुख ढांचे की सार्वजनिक रूप से दिखाई देने वाली वास्तुकला को सरल बनाता है, बिना इसके कार्यात्मक समृद्धि को कम किए। वर्ग समूहों पर आधारित हैंabstract factory डिज़ाइन पैटर्न।

इसे सरल बनाने के लिए, समान कार्यों के लिए कई कक्षाएं बनाने के बजाय, हम एक एकल वर्ग बनाते हैं जो इनपुट के मूल्य के आधार पर इसकी हैंडलिंग का ध्यान रखेगा।

उदाहरण के लिए, NSNumber में हमारे पास char, int, bool इत्यादि जैसी कक्षाओं के कई क्लस्टर हैं। हम उन सभी को एक एकल वर्ग में जोड़ते हैं जो एक ही कक्षा में समान संचालन को संभालने का ध्यान रखते हैं। NSNumber वास्तव में वस्तुओं में इन आदिम प्रकारों के मूल्य को लपेटता है।

समग्र वस्तु क्या है?

निजी क्लस्टर ऑब्जेक्ट को अपने स्वयं के डिज़ाइन के ऑब्जेक्ट में एम्बेड करके, हम एक समग्र ऑब्जेक्ट बनाते हैं। यह मिश्रित वस्तु अपनी मूल कार्यक्षमता के लिए क्लस्टर ऑब्जेक्ट पर निर्भर कर सकती है, केवल संदेश को इंटरसेप्ट करती है जो समग्र वस्तु किसी विशेष तरीके से संभालना चाहती है। यह आर्किटेक्चर हमारे द्वारा लिखे जाने वाले कोड की मात्रा को कम कर देता है और आपको फाउंडेशन फ्रेमवर्क द्वारा प्रदान किए गए परीक्षण कोड का लाभ उठाने देता है।

यह निम्नलिखित आकृति में समझाया गया है।

समग्र वस्तु को स्वयं को क्लस्टर के सार सुपरक्लास का उपवर्ग घोषित करना चाहिए। एक उपवर्ग के रूप में, यह सुपरक्लास की आदिम विधियों को ओवरराइड करना चाहिए। यह व्युत्पन्न विधियों को भी ओवरराइड कर सकता है, लेकिन यह आवश्यक नहीं है क्योंकि व्युत्पन्न विधियां आदिम लोगों के माध्यम से काम करती हैं।

NSArray वर्ग की गणना विधि एक उदाहरण है; हस्तक्षेप करने वाली वस्तु के कार्यान्वयन की एक विधि जिसे वह ओवरराइड करता है वह इस प्रकार सरल हो सकती है -

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

उपरोक्त उदाहरण में, एम्बेडेड ऑब्जेक्ट वास्तव में प्रकार NSArray है।

एक समग्र वस्तु उदाहरण

अब एक संपूर्ण उदाहरण देखने के लिए, आइए Apple के दस्तावेज़ीकरण से उदाहरण देखें जो नीचे दिया गया है।

#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; {
   if (index <[embeddedArray count]) {
      [embeddedArray removeObjectAtIndex:index];
   }
}

@end

int main() {
   NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
   ValidatingArray *validatingArray = [ValidatingArray validatingArray];
   
   [validatingArray addObject:@"Object1"];
   [validatingArray addObject:@"Object2"];
   [validatingArray addObject:[NSNull null]];
   [validatingArray removeObjectAtIndex:2];
   NSString *aString = [validatingArray objectAtIndex:1];
   NSLog(@"The value at Index 1 is %@",aString);
   [pool drain];
   
   return 0;
}

अब जब हम प्रोग्राम को संकलित करते हैं और चलाते हैं, तो हमें निम्नलिखित परिणाम मिलेंगे।

2013-09-28 22:03:54.294 demo[6247] The value at Index 1 is Object2

उपरोक्त उदाहरण में, हम देख सकते हैं कि सरणी के एक फ़ंक्शन को मान्य करने से अशक्त वस्तुओं को जोड़ने की अनुमति नहीं मिलेगी जो सामान्य परिदृश्य में दुर्घटना का कारण बनेगी। लेकिन हमारा सत्यापन सरणी इसका ख्याल रखती है। इसी प्रकार, सरणी को मान्य करने की प्रत्येक विधि परिचालन के सामान्य अनुक्रम के अलावा मान्य प्रक्रियाओं को जोड़ती है।