उद्देश्य-सी संरचनाएं

ऑब्जेक्टिव-सी सरणियां आपको उस प्रकार के चर को परिभाषित करने की अनुमति देती हैं जो एक ही तरह के कई डेटा आइटम रख सकते हैं लेकिन structure एक अन्य उपयोगकर्ता-परिभाषित डेटा प्रकार है जो उद्देश्य-सी प्रोग्रामिंग में उपलब्ध है जो आपको विभिन्न प्रकार के डेटा आइटम को संयोजित करने की अनुमति देता है।

संरचनाएं एक रिकॉर्ड का प्रतिनिधित्व करने के लिए उपयोग की जाती हैं, मान लीजिए कि आप किसी पुस्तकालय में अपनी पुस्तकों का ट्रैक रखना चाहते हैं। आप प्रत्येक पुस्तक के बारे में निम्नलिखित विशेषताओं को ट्रैक करना चाहते हैं -

  • Title
  • Author
  • Subject
  • बुक आईडी

एक संरचना को परिभाषित करना

एक संरचना को परिभाषित करने के लिए, आपको इसका उपयोग करना चाहिए structबयान। संरचनात्मक विवरण एक नए डेटा प्रकार को परिभाषित करता है, जिसमें आपके कार्यक्रम के लिए एक से अधिक सदस्य होते हैं। संरचना विवरण का प्रारूप नीचे दिखाया गया है -

struct [structure tag] {
   member definition;
   member definition;
   ...
   member definition;
} [one or more structure variables];

structure tagवैकल्पिक है और प्रत्येक सदस्य की परिभाषा एक सामान्य परिवर्तनीय परिभाषा है, जैसे int i; या फ्लोट एफ; या कोई अन्य मान्य चर परिभाषा। संरचना की परिभाषा के अंत में, अंतिम अर्धविराम से पहले, आप एक या एक से अधिक संरचना चर निर्दिष्ट कर सकते हैं लेकिन यह वैकल्पिक है। यहाँ आप बुक संरचना को घोषित करने का तरीका है -

struct Books {
   NSString *title;
   NSString *author;
   NSString *subject;
   int   book_id;
} book;

संरचना सदस्यों तक पहुँचना

किसी संरचना के किसी भी सदस्य तक पहुँचने के लिए, हम इसका उपयोग करते हैं member access operator (.)। सदस्य एक्सेस ऑपरेटर को संरचना चर नाम और संरचना सदस्य के बीच की अवधि के रूप में कोडित किया जाता है जिसे हम एक्सेस करना चाहते हैं। आप उपयोग करेंगेstructकीवर्ड संरचना प्रकार के चर को परिभाषित करने के लिए। निम्नलिखित संरचना के उपयोग की व्याख्या करने के लिए उदाहरण है -

#import <Foundation/Foundation.h>

struct Books {
   NSString *title;
   NSString *author;
   NSString *subject;
   int   book_id;
};
 
int main() {
   struct Books Book1;        /* Declare Book1 of type Book */
   struct Books Book2;        /* Declare Book2 of type Book */
 
   /* book 1 specification */
   Book1.title = @"Objective-C Programming";
   Book1.author = @"Nuha Ali"; 
   Book1.subject = @"Objective-C Programming Tutorial";
   Book1.book_id = 6495407;

   /* book 2 specification */
   Book2.title = @"Telecom Billing";
   Book2.author = @"Zara Ali";
   Book2.subject = @"Telecom Billing Tutorial";
   Book2.book_id = 6495700;
 
   /* print Book1 info */
   NSLog(@"Book 1 title : %@\n", Book1.title);
   NSLog(@"Book 1 author : %@\n", Book1.author);
   NSLog(@"Book 1 subject : %@\n", Book1.subject);
   NSLog(@"Book 1 book_id : %d\n", Book1.book_id);

   /* print Book2 info */
   NSLog(@"Book 2 title : %@\n", Book2.title);
   NSLog(@"Book 2 author : %@\n", Book2.author);
   NSLog(@"Book 2 subject : %@\n", Book2.subject);
   NSLog(@"Book 2 book_id : %d\n", Book2.book_id);

   return 0;
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

2013-09-14 04:20:07.947 demo[20591] Book 1 title : Objective-C Programming
2013-09-14 04:20:07.947 demo[20591] Book 1 author : Nuha Ali
2013-09-14 04:20:07.947 demo[20591] Book 1 subject : Objective-C Programming Tutorial
2013-09-14 04:20:07.947 demo[20591] Book 1 book_id : 6495407
2013-09-14 04:20:07.947 demo[20591] Book 2 title : Telecom Billing
2013-09-14 04:20:07.947 demo[20591] Book 2 author : Zara Ali
2013-09-14 04:20:07.947 demo[20591] Book 2 subject : Telecom Billing Tutorial
2013-09-14 04:20:07.947 demo[20591] Book 2 book_id : 6495700

फ़ंक्शन तर्क के रूप में संरचनाएं

आप किसी अन्य वैरिएबल या पॉइंटर को पास करते समय एक संरचना तर्क के रूप में एक फ़ंक्शन तर्क के रूप में पारित कर सकते हैं। आप संरचना चर को उसी तरह एक्सेस करेंगे जैसे आपने उपरोक्त उदाहरण में एक्सेस किया है -

#import <Foundation/Foundation.h>

struct Books {
   NSString *title;
   NSString *author;
   NSString *subject;
   int   book_id;
};

@interface SampleClass:NSObject
/* function declaration */
- (void) printBook:( struct Books) book ;
@end

@implementation SampleClass 

- (void) printBook:( struct Books) book {
   NSLog(@"Book title : %@\n", book.title);
   NSLog(@"Book author : %@\n", book.author);
   NSLog(@"Book subject : %@\n", book.subject);
   NSLog(@"Book book_id : %d\n", book.book_id);
}

@end

int main() {
   struct Books Book1;        /* Declare Book1 of type Book */
   struct Books Book2;        /* Declare Book2 of type Book */
 
   /* book 1 specification */
   Book1.title = @"Objective-C Programming";
   Book1.author = @"Nuha Ali"; 
   Book1.subject = @"Objective-C Programming Tutorial";
   Book1.book_id = 6495407;

   /* book 2 specification */
   Book2.title = @"Telecom Billing";
   Book2.author = @"Zara Ali";
   Book2.subject = @"Telecom Billing Tutorial";
   Book2.book_id = 6495700;
 
   SampleClass *sampleClass = [[SampleClass alloc]init];
   /* print Book1 info */
   [sampleClass printBook: Book1];

   /* Print Book2 info */
   [sampleClass printBook: Book2];

   return 0;
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

2013-09-14 04:34:45.725 demo[8060] Book title : Objective-C Programming
2013-09-14 04:34:45.725 demo[8060] Book author : Nuha Ali
2013-09-14 04:34:45.725 demo[8060] Book subject : Objective-C Programming Tutorial
2013-09-14 04:34:45.725 demo[8060] Book book_id : 6495407
2013-09-14 04:34:45.725 demo[8060] Book title : Telecom Billing
2013-09-14 04:34:45.725 demo[8060] Book author : Zara Ali
2013-09-14 04:34:45.725 demo[8060] Book subject : Telecom Billing Tutorial
2013-09-14 04:34:45.725 demo[8060] Book book_id : 6495700

पॉइंट टू स्ट्रक्चर्स

आप संरचनाओं को बिंदुओं को उसी तरह से परिभाषित कर सकते हैं जैसे आप सूचक को किसी अन्य चर के रूप में परिभाषित करते हैं -

struct Books *struct_pointer;

अब, आप उपरोक्त परिभाषित सूचक चर में एक संरचना चर के पते को संग्रहीत कर सकते हैं। संरचना चर का पता खोजने के लिए, संरचना के नाम से पहले ऑपरेटर को निम्नानुसार रखें -

struct_pointer = &Book1;

किसी संरचना के सदस्यों को उस संरचना के लिए एक सूचक का उपयोग करने के लिए, आपको निम्नानुसार -> ऑपरेटर का उपयोग करना होगा -

struct_pointer->title;

हमें संरचना सूचक का उपयोग करके उदाहरण के ऊपर फिर से लिखना चाहिए, आशा है कि यह आपके लिए अवधारणा को समझना आसान होगा -

#import <Foundation/Foundation.h>

struct Books {
   NSString *title;
   NSString *author;
   NSString *subject;
   int   book_id;
};

@interface SampleClass:NSObject
/* function declaration */
- (void) printBook:( struct Books *) book ;
@end

@implementation SampleClass 
- (void) printBook:( struct Books *) book {
   NSLog(@"Book title : %@\n", book->title);
   NSLog(@"Book author : %@\n", book->author);
   NSLog(@"Book subject : %@\n", book->subject);
   NSLog(@"Book book_id : %d\n", book->book_id);
}

@end

int main() {
   struct Books Book1;        /* Declare Book1 of type Book */
   struct Books Book2;        /* Declare Book2 of type Book */
 
   /* book 1 specification */
   Book1.title = @"Objective-C Programming";
   Book1.author = @"Nuha Ali"; 
   Book1.subject = @"Objective-C Programming Tutorial";
   Book1.book_id = 6495407;

   /* book 2 specification */
   Book2.title = @"Telecom Billing";
   Book2.author = @"Zara Ali";
   Book2.subject = @"Telecom Billing Tutorial";
   Book2.book_id = 6495700;
 
   SampleClass *sampleClass = [[SampleClass alloc]init];
   /* print Book1 info by passing address of Book1 */
   [sampleClass printBook:&Book1];

   /* print Book2 info by passing address of Book2 */
   [sampleClass printBook:&Book2];

   return 0;
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

2013-09-14 04:38:13.942 demo[20745] Book title : Objective-C Programming
2013-09-14 04:38:13.942 demo[20745] Book author : Nuha Ali
2013-09-14 04:38:13.942 demo[20745] Book subject : Objective-C Programming Tutorial
2013-09-14 04:38:13.942 demo[20745] Book book_id : 6495407
2013-09-14 04:38:13.942 demo[20745] Book title : Telecom Billing
2013-09-14 04:38:13.942 demo[20745] Book author : Zara Ali
2013-09-14 04:38:13.942 demo[20745] Book subject : Telecom Billing Tutorial
2013-09-14 04:38:13.942 demo[20745] Book book_id : 6495700

बिट फील्ड्स

बिट फील्ड्स एक संरचना में डेटा की पैकिंग की अनुमति देता है। यह विशेष रूप से तब उपयोगी होता है जब मेमोरी या डेटा स्टोरेज प्रीमियम पर होता है। विशिष्ट उदाहरण -

  • कई वस्तुओं को मशीन शब्द में पैक करना। उदाहरण के लिए 1 बिट फ़्लैग को कॉम्पैक्ट किया जा सकता है।

  • बाहरी फ़ाइल स्वरूपों को पढ़ना - गैर-मानक फ़ाइल स्वरूपों को पढ़ा जा सकता है। उदा 9 बिट पूर्णांक।

वस्तुनिष्ठ-सी हमें संरचना संरचना में यह करने की अनुमति देता है: चर के बाद की लंबाई। उदाहरण के लिए -

struct packed_struct {
   unsigned int f1:1;
   unsigned int f2:1;
   unsigned int f3:1;
   unsigned int f4:1;
   unsigned int type:4;
   unsigned int my_int:9;
} pack;

यहाँ, pack_struct में 6 सदस्य हैं: चार 1 बिट फ़्लैग f1..f3, एक 4 बिट प्रकार और 9 बिट my_int।

ऑब्जेक्टिव-सी स्वचालित रूप से उपरोक्त बिट फ़ील्ड को यथासंभव कॉम्पैक्ट रूप से पैक करता है, बशर्ते कि फ़ील्ड की अधिकतम लंबाई कंप्यूटर के पूर्णांक शब्द की लंबाई से कम या उसके बराबर हो। यदि यह मामला नहीं है, तो कुछ कंपाइलर फ़ील्ड के लिए मेमोरी ओवरलैप की अनुमति दे सकते हैं, जबकि अन्य अगले शब्द में अगले फ़ील्ड को संग्रहीत करेगा।