> For the complete documentation index, see [llms.txt](https://ios.howtocode.dev/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://ios.howtocode.dev/objc-intro/8.md).

# ক্যাটাগরি

**ভূমিকাঃ** সংক্ষেপে বলতে গেলে ক্যাটাগরি হচ্ছে একটি ক্লাসের ডেফিনেশনকে অনেক গুলো আলাদা আলাদা ফাইলে ভাগ করে নেয়া। অনেক বড় কোড বেজে কাজ করার সময় একটি ক্লাসের মডিউলারাইজেশন করাই এর উদ্দেশ্য। মডিউলারাইজেশন বলতে বোঝানো হচ্ছে যে, একটি বড় ক্লাসকে ছোট ছোট অনেক গুলো স্বাধীন অংশ হিসেবে তৈরি করার একটা প্যাটার্ন।

[![category](http://nuhil.files.wordpress.com/2014/06/category.png?w=300)](https://nuhil.files.wordpress.com/2014/06/category.png) উপরের ছবিটিতে এটাই প্রকাশ করা হয়েছে যে, একাধিক ফাইল অর্থাৎ Cook.m এবং Cook+Costing.m মিলে Cook ক্লাসের পূর্ণাঙ্গ ইমপ্লিমেন্টেশন সম্পন্ন হয়েছে। নিচের উদাহরণের মাধ্যমে আমরা আরও পরিষ্কার ধারনা পাবো যেখানে, একটি ক্যাটাগরি ব্যবহার করে একটি বেজ ক্লাসকে এক্সটেন্ড করব অর্থাৎ বেজ ক্লাসের অ্যাসেট হিসেবে আরও কিছু মেথড যুক্ত করব কিন্তু বেজ ক্লাসটির সোর্স বা কোন কিছু পরিবর্তন না করেই।

**উদাহরণ এর পটভূমি তৈরিঃ** কথামত, ক্যাটাগরির ব্যবহার বুঝতে হলে আমাদের এক সেট বেজ ক্লাস দরকার পরবে। আর তাই নিচের মত করে একটি ক্লিন প্রজেক্টে Cook ক্লাস তৈরি করে নিন যেটা এক্ষেত্রে আমাদের বেজ ক্লাস।

```
Cook.h

#import <Foundation/Foundation.h>

@interface Cook : NSObject

@property (copy) NSString *item;

- (void)placeOrder;
- (void)startCooking;

@end
```

```
Cook.m

#import "Cook.h"

@implementation Cook

-(void) placeOrder {
    NSLog(@"Order placed for a %@", self.item);
}

-(void) startCooking {
    NSLog(@"Started cooking %@", self.item);
}

@end
```

আশা করি উপরের সাধারণ ক্লাস ডেফিনেশনটা বুঝতে পেরেছেন। এভাবে আগে আমরা অনেক বারই ক্লাস তৈরি করেছি যেখানে একটি ইন্টারফেস ফাইল এবং একটি ইমপ্লিমেন্টেশন ফাইল মিলে একটি পূর্ণ ক্লাস ডেফিনেশন সম্পন্ন হয়। এখন মনে করুন যে, আপনি রান্না (Cook) সম্পর্কিত আরও কিছু মেথড যুক্ত করতে চাচ্ছেন কিন্তু Cook ক্লাস এর কোন কিছু পরিবর্তন না করে বা সেটার গঠন নষ্ট না করে। এই ক্ষেত্রে আপনি ওই নতুন মেথড গুলো একটি ক্যাটাগরিতে যুক্ত করতে পারেন। ধরুন, আমরা চাই Cooking সম্পর্কিত খরচ এর হিসাবের একটি নতুন মেথড যুক্ত করতে।

**ক্যাটাগরি তৈরিঃ** ক্যাটাগরির ডেফিনিনেশন এবং ক্লাসের ডেফিনেশন মোটা মুটি একি রকম অর্থাৎ এরও ইন্টারফেস এবং ইমপ্লিমেন্টেশন মিলেই সম্পূর্ণতা হয়। আমাদের প্রজেক্টে নতুন Cook+Costing নামের ক্যাটাগরি যুক্ত করতে হলে Xcode এর New File অপশন থেকে নিচের মত করে এই ক্যাটাগরিটি তৈরি ও প্রজেক্টে যুক্ত করুন। ক্যাটাগরির নাম দিচ্ছি Costing এবং Category On হিসেবে লিখতে/সিলেক্ট করতে হবে Cook. [![Screen Shot 2014-06-09 at 9.15.28 PM](http://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-15-28-pm.png?w=460)](https://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-15-28-pm.png)

[![Screen Shot 2014-06-09 at 9.15.59 PM](http://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-15-59-pm.png?w=460)](https://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-15-59-pm.png)

তাহলে আমাদের প্রজেক্টে ফাইল স্ট্রাকচার হবে নিচের মত, [![Screen Shot 2014-06-09 at 9.16.19 PM](http://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-16-19-pm.png)](https://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-16-19-pm.png)

এখন একটু খেয়াল করলেই দেখবেন ক্যাটাগরির ইন্টারফেস ফাইল এবং সাধারণ ক্লাসের ইন্টারফেস ফাইল একি রকম দেখতে শুধু @interface এর পর ক্লাসের নাম এবং তারপর ব্রাকেটের মধ্যে ক্যাটাগরির নাম উল্লেখ করতে হয়। নিচে আমাদের Cook+Costing এর ইন্টারফেস,

```
Cook+Costing.h

#import "Cook.h"

@interface Cook (Costing)

- (BOOL)isFreeOfferOngoing;
- (void)calculatePrice;

@end
```

রানটাইমে এই মেথড দুটো Cook ক্লাসের অংশ হিসেবেই কাজ করে। যদিও এগুলো আলাদা একটা ফাইলে ডিফাইন করা হল তবুও এগুলোকে এমন ভাবে এক্সেস করা যাবে যেন মনে হবে এগুলো Cook ক্লাসের মেথড। আর আগেই বলা হয়েছে ক্যাটাগরির ইমপ্লিমেন্টেশনও লাগবে (সাধারণ ক্লাসের মতই)। তাই নিচের মত করে Cook+Costing.m ফাইলটি পরিবর্তন করুন,

```
Cook+Costing.m

#import "Cook+Costing.h"

@implementation Cook (Costing)

-(BOOL) isFreeOfferOngoing {
    return NO;
}

-(void)calculatePrice {
    NSLog(@"Price of %@ would be 350 tk.", self.item);
}

@end
```

**ব্যবহারঃ** যেকোনো ফাইল কোন একটি ক্যাটাগরির যেকোনো একটি API (ইন্টারফেস লেয়ার) ব্যবহার করতে চাইলে তাকে অবশ্যই ওই ক্যাটাগরির হেডার ফাইলে যুক্ত করে নিতে হবে। অর্থাৎ নিচের মত করে main.m ফাইলে প্রথমে আমাদেরকে Cook ক্লাসের হেডার এবং তারপরে Cook+Costing ক্যাটাগরির হেডার যুক্ত করতে নিতে হবে,

```
main.m

#import <Foundation/Foundation.h>
#import "Cook.h"
#import "Cook+Costing.h"

int main(int argc, const char * argv[])
{

    @autoreleasepool {
        Cook *forMe = [[Cook alloc] init];
        forMe.item = @"Italian Pizza";

        // "Standard" functionality from Cook.h
        [forMe placeOrder];
        [forMe startCooking];

        // Additional methods from Cook+Costing.h
        if (![forMe isFreeOfferOngoing]) {
            [forMe calculatePrice];
        }

    }
    return 0;
}
```

উপরে খেয়াল করুন, খুব সুন্দর ভাবে Cook ক্লাসের ফাংশনালিটি গুলো আমরা এক্সেস করতে পারছি এবং সাথে ওই ক্লাসের অবজেক্ট বা ইন্সট্যান্স দিয়েই কিন্তু Costing ক্যাটাগরির মাধ্যমে Cooking এর জন্য অতিরিক্ত প্রয়োজনীয় মেথড যেগুলো নতুন ক্যাটগরি হিসেবে ডিফাইন করা হয়েছে সেগুলোও এক্সেস করতে পারছি ১৯-২১ নাম্বার লাইনে। প্রোজেক্টটি রান করালে নিচের মত আউটপুট আসবে।

[![Screen Shot 2014-06-09 at 9.51.49 PM](http://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-51-49-pm.png?w=460)](https://nuhil.files.wordpress.com/2014/06/screen-shot-2014-06-09-at-9-51-49-pm.png)

**প্রোটেক্টেড মেথড হিসেবে ক্যাটাগরিঃ** আশা করি এই বিষয়ে আমাদের সম্ভাব্য কাগুজে বইয়ে বিস্তারিত আলোচনা থাকবে।

**এক্সটেনশনঃ** আশা করি এই বিষয়ে আমাদের সম্ভাব্য কাগুজে বইয়ে বিস্তারিত আলোচনা থাকবে।

Originally Posted [Here](http://nuhil.net/2014/06/09/৮-অবজেক্টিভ-সি-এর-ক্যাটাগ/)


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter, and the optional `goal` query parameter:

```
GET https://ios.howtocode.dev/objc-intro/8.md?ask=<question>&goal=<endgoal>
```

`ask` is the immediate question: it should be specific, self-contained, and written in natural language.
`goal` is optional and describes the broader end goal you are ultimately trying to accomplish on behalf of the user. GitBook uses it to tailor the answer towards what is most useful for that goal.

The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
