সি ক্লাসে ব্যক্তিগত সদস্যের ফাংশনগুলি encapsulate করতে বন্ধু শ্রেণি ব্যবহার করে - ভাল অনুশীলন বা আপত্তিজনক?


12

সুতরাং আমি লক্ষ্য করেছি যে হেডারগুলিতে এই জাতীয় কিছু করে ব্যক্তিগত ফাংশন স্থাপন এড়ানো সম্ভব:

// In file pred_list.h:
    class PredicateList
    {
        int somePrivateField;
        friend class PredicateList_HelperFunctions;
    public:
        bool match();
    } 

// In file pred_list.cpp:
    class PredicateList_HelperFunctions
    {
        static bool fullMatch(PredicateList& p)
        {
            return p.somePrivateField == 5; // or whatever
        }
    }

    bool PredicateList::match()
    {
        return PredicateList_HelperFunctions::fullMatch(*this);
    }

ব্যক্তিগত ফাংশনটি কখনই শিরোনামে ঘোষিত হয় না, এবং শিরোনামটি আমদানি করে এমন শ্রেণীর গ্রাহকরা কখনও এটির উপস্থিতি জানতে হবে না। এটির প্রয়োজন যদি সহায়ক ফাংশনটি একটি টেম্পলেট হয় (বিকল্পটি পুরো শিরোনামটিতে পুরো কোডটি প্রবিষ্ট করছে), যা আমি এটি "আবিষ্কার" করেছি discovered আপনি যদি কোনও ব্যক্তিগত সদস্য ফাংশন যুক্ত / অপসারণ / সংশোধন করেন তবে প্রতিটি ফাইলের পুনরায় সংকলন করার দরকার নেই এর অপর একটি সুন্দর উল্টো দিক। সমস্ত ব্যক্তিগত ফাংশন .cpp ফাইলে থাকে।

তাই ...

  1. এটি কি একটি নামী নকশার প্যাটার্ন যার নাম রয়েছে?
  2. আমার কাছে (জাভা / সি # ব্যাকগ্রাউন্ড থেকে আসা এবং নিজের সময়ে সি ++ শিখতে), এটি একটি খুব ভাল জিনিস বলে মনে হচ্ছে, যেহেতু শিরোনাম একটি ইন্টারফেসকে সংজ্ঞায়িত করছে, যখন .cpp একটি বাস্তবায়ন সংজ্ঞায়িত করছে (এবং উন্নত সংকলনের সময়টি একটি দুর্দান্ত বোনাস)। তবে এটিরও গন্ধ লাগে যে এটি কোনও ভাষার বৈশিষ্ট্যকে অপব্যবহার করে যা সেভাবে ব্যবহারের উদ্দেশ্যে নয়। তো, এটি কোনটি? এটি কি পেশাদার সি ++ প্রকল্পে দেখে আপনি ভ্রান্ত হয়ে উঠবেন?
  3. আমি কোন সমস্যার কথা ভাবছি না?

আমি পিম্পল সম্পর্কে সচেতন, যা গ্রন্থাগারের প্রান্তে বাস্তবায়নটি গোপন করার অনেক বেশি শক্তিশালী উপায়। এটি অভ্যন্তরীণ ক্লাসগুলির সাথে ব্যবহারের জন্য আরও বেশি যেখানে পিম্পল কর্মক্ষমতা সংক্রান্ত সমস্যা সৃষ্টি করবে বা কাজ করবে না কারণ শ্রেণিকে একটি মান হিসাবে বিবেচনা করা দরকার।


সম্পাদনা 2: ড্রাগন শক্তির নিচে দুর্দান্ত উত্তর নীচের সমাধানটির পরামর্শ দিয়েছে, যা মূলশব্দটি মোটেই ব্যবহার করে না friend:

// In file pred_list.h:
    class PredicateList
    {
        int somePrivateField;
        class Private;
    public:
        bool match();
    } 

// In file pred_list.cpp:
    class PredicateList::Private
    {
    public:
        static bool fullMatch(PredicateList& p)
        {
            return p.somePrivateField == 5; // or whatever
        }
    }

    bool PredicateList::match()
    {
        return PredicateList::Private::fullMatch(*this);
    }

এটি পৃথকীকরণের একই নীতিটি বজায় রেখে friend(যা দেখে মনে হয় goto) এর শক ফ্যাক্টর এড়ায় ।


2
" কোনও গ্রাহক তাদের নিজস্ব শ্রেণি প্রডিকেটলিস্টহেল্পার ফাংশনগুলি সংজ্ঞায়িত করতে পারে এবং তাদের ব্যক্তিগত ক্ষেত্রগুলিতে অ্যাক্সেস করতে দেয় " "এটি কি ওডিআর লঙ্ঘন হবে না ? আপনি এবং গ্রাহক উভয়ই একই শ্রেণীর সংজ্ঞা দিতে হবে। যদি সেই সংজ্ঞাগুলি সমান না হয়, তবে কোডটি খারাপভাবে গঠিত।
নিকল বোলাস

উত্তর:


13

আপনি ইতিমধ্যে স্বীকৃত হিসাবে যা আপনি একটি মুহুর্তের জন্য আমার মাথা আঁচড়ানো শুরু করতে পারেন যখন আপনি প্রথমে আপনার কোডটির মুখোমুখি হওয়া শুরু করছেন আপনি কী করছেন এবং এই স্টাইলার ক্লাসগুলি কার্যকর করা হচ্ছে যতক্ষণ না আমি আপনার স্টাইলটি বেছে নেওয়া শুরু করি ততক্ষণে এটি কিছুটা রহস্যজনক বলা যায় / অভ্যাস (কোন পর্যায়ে আমি এটির সাথে পুরোপুরি অভ্যস্ত হতে পারি)

আমি এর মতো করি আপনি শিরোনামগুলিতে তথ্যের পরিমাণ হ্রাস করছেন। বিশেষত খুব বড় কোডবেসে, এটি সংকলন-সময় নির্ভরতা হ্রাস করতে এবং শেষ পর্যন্ত সময় তৈরিতে ব্যবহারিক প্রভাব ফেলতে পারে।

আমার অন্ত্রের প্রতিক্রিয়াটি হ'ল যদি আপনি যদি এইভাবে প্রয়োগের বিশদটি গোপন করার প্রয়োজন বোধ করেন তবে উত্স ফাইলে অভ্যন্তরীণ লিঙ্কেজের সাথে মুক্ত-স্থায়ী ফাংশনগুলিতে পরামিতিটি পাস করার পক্ষে। সাধারণত আপনি শ্রেণীর সমস্ত ইন্টার্নাল অ্যাক্সেস না করে নির্দিষ্ট শ্রেণীর প্রয়োগের জন্য দরকারী ইউটিলিটি ফাংশন (বা পুরো ক্লাস) কার্যকর করতে পারেন এবং পরিবর্তে কোনও পদ্ধতি প্রয়োগ বা ফাংশন (বা কনস্ট্রাক্টর) এ প্রাসঙ্গিক বিষয়গুলিতে পাস করতে পারেন। এবং স্বাভাবিকভাবেই এতে আপনার বর্গ এবং "সহায়ক" এর মধ্যে সংযোগ হ্রাস করার বোনাস রয়েছে। এতে আরও সাধারণীকরণের প্রবণতা রয়েছে যা অন্যথায় "সহায়ক" হতে পারে যদি আপনি দেখেন যে তারা একাধিক শ্রেণীর প্রয়োগের জন্য প্রযোজ্য আরও সাধারণীকরণ উদ্দেশ্যে পরিবেশন করতে শুরু করেছেন।

আমি কোডটিতে প্রচুর "সহায়তাকারী" দেখলে আমি কখনও কখনও কিছুটা ক্রিঙ্কও করি। এটি সর্বদা সত্য নয় তবে কখনও কখনও তারা এমন বিকাশকারী ব্যক্তির লক্ষণ হতে পারে যিনি কেবলমাত্র ডাবলিকেশনকে বিপদজনক নাম / উদ্দেশ্যগুলির সাথে ফাংশনগুলিতে পাস করে যাচ্ছেন যে এই পরিমাণের পরিমাণ হ্রাস করে তার সাথে কোড ডুপ্লিকেশন দূর করতে কেবল উইল-নিলি ফাংশনগুলি দ্রবীভূত করছেন functions কিছু অন্যান্য ক্রিয়াকলাপ বাস্তবায়নের জন্য কোড প্রয়োজন। সামান্য কিশোর বিট আরও চিন্তাভাবনা কখনও কখনও শ্রেণীর বাস্তবায়ন কীভাবে আরও কার্যকরীভাবে বিভক্ত হয় তার দিক থেকে আরও বৃহত্তর স্পষ্টতার দিকে নিয়ে যেতে পারে এবং অভ্যন্তরীণ অভ্যন্তরে সম্পূর্ণ অ্যাক্সেসের সাথে আপনার অবজেক্টের পুরো উদাহরণগুলি পাস করার জন্য নির্দিষ্ট পরামিতিগুলি পাশ করার পক্ষে সহায়তা করতে পারে নকশা চিন্তার যে স্টাইল প্রচার। আমি প্রস্তাব দিচ্ছি না যে আপনি এটি করছেন অবশ্যই, (আমার কোনও ধারণা নেই),

যদি এটি অযৌক্তিক হয়ে যায়, আমি একটি দ্বিতীয়, আরও মুশকিল সমাধান বিবেচনা করব যা পিম্পল (আমি বুঝতে পেরেছি যে আপনি এটির সাথে সমস্যাগুলি উল্লেখ করেছেন তবে আমি মনে করি যে ন্যূনতম প্রচেষ্টা সহকারে এড়াতে আপনি কোনও সমাধানকে সাধারণীকরণ করতে পারেন)। এটি হেডার হোলসেল থেকে দূরে আপনার ব্যক্তিগত ডেটা সহ আপনার ক্লাসে প্রয়োগ করা দরকার এমন প্রচুর তথ্য সরিয়ে নিতে পারে। পিম্পলের পারফরম্যান্স ইস্যুগুলি মূলত একটি ময়লা-সস্তা ধ্রুবক-সময় বরাদ্দকারী * একটি মুক্ত তালিকার মতো কমিয়ে দেওয়া যেতে পারে যখন পূর্ণ-বিকাশযুক্ত ব্যবহারকারী-সংজ্ঞায়িত অনুলিপি কপির ব্যবহার না করে মান শব্দার্থ সংরক্ষণ করে।

  • পারফরম্যান্স দিকটির জন্য পিম্পল খুব কমপক্ষে একটি পয়েন্টার ওভারহেড প্রবর্তন করে তবে আমি মনে করি মামলাগুলি বেশ গুরুতর হতে হবে যেখানে ব্যবহারিক উদ্বেগ তৈরি হয়েছে। যদি স্থানিক স্থানটি বরাদ্দকারীর মাধ্যমে উল্লেখযোগ্যভাবে অবনতি না হয়, তবে আপনার টাইট লুপগুলি বস্তুর উপরে পুনরাবৃত্তি করে (যা সাধারনত একজাত হওয়া উচিত যদি পারফরম্যান্স কোনও উদ্বেগের বিষয় থাকে) তখনও অনুশীলনে ক্যাশে মিস হ্রাস করতে পারে যদি আপনি কিছু ব্যবহার করেন তবে ক্লাসের ক্ষেত্রগুলিকে মূলত স্বতঃস্ফূর্ত মেমোরি ব্লকগুলিতে স্থাপন করে পিম্পল বরাদ্দ করার জন্য একটি বিনামূল্যে তালিকা।

ব্যক্তিগতভাবে কেবলমাত্র সেই সম্ভাবনাগুলি শেষ করে দেওয়ার পরে আমি এই জাতীয় কিছু বিবেচনা করব। আমি মনে করি যে বিকল্পটি যদি শিরোনামের সামনে প্রকাশিত আরও বেসরকারী পদ্ধতির মতো হয় তবে এটির মধ্যে কেবলমাত্র উদ্ভাবনী প্রকৃতির ব্যবহারিক উদ্বেগ।

একটি বিকল্প

একটি বিকল্প যা এখনই আমার মাথায় pedুকে পড়েছে যে আপনার অনুপস্থিত বন্ধুবান্ধব বন্ধুদের বহুলাংশে সাধিত করে তা হ'ল:

struct PredicateListData
{
     int somePrivateField;
};

class PredicateList
{
    PredicateListData data;
public:
    bool match() const;
};

// In source file:
static bool fullMatch(const PredicateListData& p)
{
     // Can access p.somePrivateField here.
}

bool PredicateList::match() const
{
     return fullMatch(data);
}

এখন এটি খুব জটিল পার্থক্যের মতো মনে হতে পারে এবং আমি এখনও এটিকে "সহায়ক" বলব (সম্ভবত অবজ্ঞাপূর্ণ অর্থে যেহেতু আমরা এখনও ক্লাসের পুরো অভ্যন্তরীণ অবস্থাটি ফাংশনে প্রেরণ করছি, এটির সমস্ত প্রয়োজন হয় না বা না) ছাড়া আর সম্মুখীন এর "শক" ফ্যাক্টর এড়াতে নেই friend। সাধারণভাবে friendআরও পরিদর্শন অনুপস্থিত দেখতে দেখতে কিছুটা ভীতিজনক মনে হয়, কারণ এটি বলে যে আপনার শ্রেণীর অভ্যন্তরগুলি অন্য কোথাও অ্যাক্সেসযোগ্য (যা বোঝায় যে এটি তার নিজস্ব আক্রমণকারীগুলি বজায় রাখতে অক্ষম হতে পারে)। যেভাবে আপনি এটি ব্যবহার করছেন friendতা যদি না হয় তবে লোকেরা অনুশীলন সম্পর্কে সচেতন হলে ootfriendক্লাসের ব্যক্তিগত কার্যকারিতা বাস্তবায়নে সহায়তা করতে কেবল একই উত্স ফাইলটিতে বাস করছে, তবে উপরেরটি কমপক্ষে এক যুক্তিযুক্ত উপকারের সাথে কমপক্ষে একই প্রভাবটি অর্জন করে যে এতে কোনও বন্ধু জড়িত না যা পুরো ধরণের এড়িয়ে চলে ("ওহ অঙ্কুর করুন, এই শ্রেণীর একটি বন্ধু আছে its এর প্রাইভেটগুলি অন্য কোথা থেকে অ্যাক্সেস / মিউটেশন পায়? ")। যদিও উপরের সংস্করণটি তাত্ক্ষণিকভাবে যোগাযোগ করে যে প্রাইভেটের পক্ষে প্রয়োগের ক্ষেত্রে যে কোনও কিছু করার বাইরে প্রবেশ / পরিবর্তন করার কোনও উপায় নেই PredicateList

এটি সম্ভবত এই স্তরের স্তরের সাথে কিছুটা কৌতুকপূর্ণ অঞ্চলের দিকে এগিয়ে চলেছে যেহেতু আপনি যদি অভিন্নরূপে জিনিসগুলির নাম লেখেন *Helper*এবং সেগুলিকে একই উত্স ফাইলে রাখেন যে কোনও শ্রেণীর ব্যক্তিগত প্রয়োগের অংশ হিসাবে এটি সমস্ত ধরণের একসাথে বান্ডিল রয়েছে। তবে আমরা যদি নিট-পিকি হয়ে যাই তবে সম্ভবত অবিলম্বে উপরের স্টাইলটি এক নজরে হাঁটু-ঝাঁকুনির প্রতিক্রিয়া সৃষ্টি করবে না friendযা মূল শব্দটি অনুপস্থিত যা কিছুটা ভীতিজনক দেখাচ্ছে।

অন্যান্য প্রশ্নের জন্য:

একজন ভোক্তা তাদের নিজস্ব শ্রেণি প্রডিকেটলিস্টহেল্পার ফাংশনগুলি সংজ্ঞায়িত করতে পারে এবং তাদের ব্যক্তিগত ক্ষেত্রগুলিতে অ্যাক্সেস করতে দেয়। যদিও আমি এটিকে একটি বিশাল সমস্যা হিসাবে দেখছি না (যদি আপনি সত্যিই সেই ব্যক্তিগত ক্ষেত্রগুলিতে কিছুটা ingালাই করতে পারেন), সম্ভবত এটি গ্রাহকরা সেভাবে এটি ব্যবহার করতে উত্সাহিত করবে?

এটি এপিআই সীমানা জুড়ে একটি সম্ভাবনা হতে পারে যেখানে ক্লায়েন্ট একই নামের সাথে একটি দ্বিতীয় শ্রেণির সংজ্ঞা দিতে পারে এবং লিংকেজ ত্রুটি ছাড়াই সেইভাবে ইন্টার্নালগুলিতে অ্যাক্সেস পেতে পারে। তারপরে আবার আমি গ্রাফিক্সে বেশিরভাগ ক্ষেত্রে সি সিডার কাজ করছি যেখানে "কী যদি" ​​এই স্তরে সুরক্ষা উদ্বেগ অগ্রাধিকার তালিকার খুব কম, তাই এই জাতীয় উদ্বেগগুলি কেবলমাত্র আমি হাত ন্যাড়া করতে চাই এবং একটি নাচ করি এবং তাদের অস্তিত্ব নেই এমন ভান করার চেষ্টা করুন। :-D আপনি যদি এমন কোনও ডোমেইনে কাজ করছেন যেখানে এই ধরণের উদ্বেগগুলি বরং গুরুতর, তবে আমি মনে করি এটি করা একটি শালীন বিবেচনা।

উপরের বিকল্প প্রস্তাবনাও এই সমস্যাটি ভোগ করা এড়িয়ে চলে। আপনি যদি এখনও ব্যবহার করতে আটকে থাকতে চান friendতবে আপনি সাহায্যকারীকে একটি ব্যক্তিগত নেস্টেড বর্গ তৈরি করেও এই সমস্যাটি এড়াতে পারেন।

class PredicateList
{
    ...

    // Declare nested class.
    class Helper;

    // Make it a friend.
    friend class Helper;

public:
    ...
};

// In source file:
class PredicateList::Helper
{
    ...
};

এটি কি একটি নামী নকশার প্যাটার্ন যার নাম রয়েছে?

আমার জ্ঞানের কেউ নেই। আমি সত্যিই বাস্তবায়নের বিবরণ এবং শৈলীর সংক্ষিপ্তকরণের মধ্যে প্রবেশ করায় একটি সন্দেহ থাকবে one

"সাহায্যকারী জাহান্নাম"

আমি প্রচুর "সহায়ক" কোডের সাথে বাস্তবায়নগুলি যখন দেখি তখন কীভাবে আমি কখনও কখনও ক্রিঙ করি সে সম্পর্কে এই বিষয়ে আরও স্পষ্টতার জন্য আমার একটি অনুরোধ পেল এবং এটি কিছুটির সাথে সামান্য বিতর্কিত হতে পারে তবে আমি সত্যই সত্য কারণ আমি যখন কিছু ডিবাগ করছিলাম তখন সত্যই ক্রিংজ হয়েছিল did আমার সহকর্মীদের কেবলমাত্র "সহায়তাকারী" এর বোঝা সন্ধানের জন্য একটি শ্রেণীর প্রয়োগ করা। :-D এবং এই সমস্ত সাহায্যকারীদের ঠিক কী করণীয় তা অনুমান করার চেষ্টা করে আমার মাথার স্ক্র্যাচ করা দলের মধ্যে আমিই ছিল না। আমি "আপনি সাহায্যকারীদের ব্যবহার করবেন না" এর মতো কৌতূহল প্রকাশ করতেও চাই না, তবে আমি একটি ছোট্ট পরামর্শ দিতে চাই যে এটি ব্যবহারিকর ক্ষেত্রে অনুপস্থিত জিনিসগুলি কীভাবে বাস্তবায়িত করা যায় তা নিয়ে ভাবতে সহায়তা করতে পারে।

সংজ্ঞা অনুসারে সমস্ত ব্যক্তিগত সদস্য ফাংশন সহায়ক ফাংশন না?

এবং হ্যাঁ, আমি ব্যক্তিগত পদ্ধতিগুলি সহ অন্তর্ভুক্ত করছি। যদি আমি একটি সহজবোধ্য প্রকাশ্য ইন্টারফেস মতো কিন্তু ব্যক্তিগত পদ্ধতির একটি অবিরাম সেট যা কিছুটা মত উদ্দেশ্য মন্দ সংজ্ঞায়িত করা হয় মত একটি বর্গ দেখতে find_implবা find_detailবা find_helper, তারপর আমিও ঠিক একই ভাবে, ধামা ধরা।

"বিকল্প হিসাবে আমি যা পরামর্শ দিচ্ছি তা হ'ল অভ্যন্তরীণ লিঙ্কেজ (ঘোষিত staticবা একটি অনামী নেমস্পেসের অভ্যন্তরে) সহ ননমেম্বার ননফ্রেন্ড ফাংশনগুলি " অন্যদের বাস্তবায়নে সহায়তা করে এমন একটি ফাংশন "এর চেয়ে কমপক্ষে আরও সাধারণ উদ্দেশ্যে আপনার শ্রেণি বাস্তবায়নে সহায়তা করার জন্য internal এবং আমি কেন সি ++ 'কোডিং স্ট্যান্ডার্ডস' থেকে ভেষজ সুটারকে এখানে উল্লেখ করতে পারি কেন এটি কোনও সাধারণ এসই দৃষ্টিকোণ থেকে পছন্দনীয়:

সদস্যপদ ফি এড়িয়ে চলুন: যেখানে সম্ভব, ফাংশন নন-মেমার ননফ্রেন্ড বানানো পছন্দ করুন। [...] ননমেম্বার ননফ্রেন্ড ফাংশন নির্ভরতা হ্রাস করে এনক্যাপসুলেশন উন্নত করে: ফাংশনের মূল অংশটি ক্লাসের অ-প্রজাতন্ত্র সদস্যের উপর নির্ভর করতে পারে না (আইটেম 11 দেখুন)। তারা পৃথকযোগ্য কার্যকারিতা মুক্ত করতে একচেটিয়া ক্লাসগুলিও ভেঙে দেয় এবং আরও সংযোজন হ্রাস করে (আইটেম 33 দেখুন)।

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

এখন সুতার এখানে ইতিমধ্যে একটি দুর্দান্ত ব্যাখ্যা দিয়েছে তবে আমি আরও যুক্ত করব যে আপনি কীভাবে ডিজাইন করেন তার কার্যকারিতা অনুসারে ডিকপলিং মানসিক উন্নতি (কমপক্ষে যদি আপনার মস্তিষ্ক আমার মতো কাজ করে) এর মতো প্রচার করে। আপনি যখন ক্লাসের সমস্ত কিছু অ্যাক্সেস করতে পারবেন না এমন ফাংশনগুলি ডিজাইন করা শুরু করেন যা কেবলমাত্র আপনি এটি পাস করেন বা আপনি যদি প্যারামিটার হিসাবে ক্লাসের উদাহরণটি পাস করেন তবে কেবল তার পাবলিক সদস্যরা, এটি এমন একটি নকশার মানসিকতার প্রচার করে যা পছন্দ করে ফাংশনগুলির একটি স্পষ্ট উদ্দেশ্য রয়েছে, ডিকপলিংয়ের উপরে এবং উন্নত এনক্যাপসুলেশনকে প্রচার করে, যা আপনি অন্যথায় ডিজাইন করতে প্রলুব্ধ হতে পারেন যদি আপনি কেবল সমস্ত কিছু অ্যাক্সেস করতে পারতেন।

আমরা যদি চূড়ান্ত দিকে ফিরে যাই তবে গ্লোবাল ভেরিয়েবলগুলির সাথে যুক্ত একটি কোডবেস বিকাশকারীদের ঠিক এমনভাবে ফাংশনগুলি ডিজাইন করতে প্ররোচিত করে না যা স্পষ্ট এবং উদ্দেশ্য অনুযায়ী সাধারণীকরণ করা হয়েছে। কোনও কার্যক্রমে আপনি যত বেশি তথ্য অ্যাক্সেস করতে পারবেন খুব তাড়াতাড়ি আমাদের মধ্যে আরও অনেক মানুষ এটির বিকাশ করার প্রলোভনের মুখোমুখি হয় এবং এই ফাংশনে আরও নির্দিষ্ট এবং প্রাসঙ্গিক পরামিতিগুলি গ্রহণ করার পরিবর্তে আমাদের কাছে থাকা এই সমস্ত অতিরিক্ত তথ্য অ্যাক্সেসের পক্ষে তার স্পষ্টতা হ্রাস করে reduce রাজ্যে এর অ্যাক্সেস সংকীর্ণ করা এবং এর প্রয়োগযোগ্যতা আরও প্রশস্ত করা এবং এর উদ্দেশ্যগুলির স্পষ্টতা উন্নত করা। এটি সদস্য ফাংশন বা বন্ধুদের সাথে (যদিও কিছুটা কম ডিগ্রীতে সাধারণত প্রযোজ্য) প্রযোজ্য।


1
ইনপুট জন্য ধন্যবাদ! আপনি এই অংশটি নিয়ে কোথা থেকে এসেছেন তা আমি পুরোপুরি বুঝতে পারি না, যদিও: "কোডটিতে প্রচুর" সহায়তাকারী "দেখলে আমিও মাঝে মাঝে কিছুটা ক্রিঞ্জ করি" " - সমস্ত ব্যক্তিগত সদস্য সংজ্ঞা অনুসারে সাহায্যকারী ফাংশন না? এটি সাধারণভাবে ব্যক্তিগত সদস্যদের কার্যক্রমে সমস্যাটি বলে মনে হচ্ছে।
রবার্ট ফ্রেজার

1
আহ, অভ্যন্তরীণ শ্রেণীর মোটেও "বন্ধু" দরকার নেই, সুতরাং এটি করা "বন্ধু" কীওয়ার্ডটিকে পুরোপুরি এড়িয়ে চলে
রবার্ট ফ্রেজার

"সংজ্ঞা অনুসারে সমস্ত ব্যক্তিগত সদস্য ফাংশন সহায়ক কাজ করে না? এটি সাধারণভাবে ব্যক্তিগত সদস্য ফাংশনগুলির সাথে ইস্যুটি নিয়েছে বলে মনে হয়।" এটি সবচেয়ে বড় জিনিস নয়। আমি মনে করি এটি একটি ব্যবহারিক প্রয়োজনীয়তা ছিল যে অ-তুচ্ছ শ্রেণীর বাস্তবায়নের জন্য আপনার একসাথে সমস্ত শ্রেণীর সদস্যদের অ্যাক্সেস সহ বেশ কয়েকটি ব্যক্তিগত ফাংশন বা সহায়ক রয়েছে। তবে আমি লিনাস টোরওয়াল্ডস, জন কারম্যাকের মতো কয়েকটি গ্রেটের স্টাইলটি দেখেছি এবং যদিও সি-তে প্রাক্তন কোডগুলি যখন সে কোনও বস্তুর সমতুল্য সমতুল্য কোড করে, তখন সে সাধারণত কারম্যাকের সাথেই এটির কোড কোড পরিচালনা করে না।
ড্রাগন এনার্জি

এবং স্বাভাবিকভাবেই আমি মনে করি উত্স ফাইলে সহায়তাকারীরা কয়েকটি বৃহত শিরোলেখের চেয়ে বেশি পছন্দনীয় যার মধ্যে প্রয়োজনীয়তার চেয়ে আরও বাহ্যিক শিরোনাম অন্তর্ভুক্ত কারণ এটি শ্রেণি বাস্তবায়নে সহায়তা করার জন্য প্রচুর ব্যক্তিগত ফাংশন ব্যবহার করে। তবে উপরোক্ত এবং অন্যদের স্টাইলটি অধ্যয়ন করার পরে, আমি বুঝতে পেরেছি যে একটি শ্রেণীর সমস্ত অভ্যন্তরীণ সদস্যদের এমনকি একটি শ্রেণি বাস্তবায়নের জন্য যে ধরণের অ্যাক্সেসের প্রয়োজন হয় তার চেয়ে কিছু বেশি সাধারণীকরণ করা ফাংশনগুলি প্রায়শই সম্ভব সম্ভব এবং চিন্তাভাবনা সামনে থেকে ফাংশনটির নাম রাখার জন্য এবং নির্দিষ্ট কাজ করার জন্য নির্দিষ্ট সদস্যদের এটি পাস করার জন্য আরও বেশি সময় সাশ্রয় হয় [...]
ড্রাগন এনার্জি

[...] যতটা লাগে তার চেয়ে পরিষ্কার পরিচ্ছন্নতার ফলস্বরূপ ফলন করা যা পরে ম্যানিপুলেট করা সহজ। এটি "সম্পূর্ণ ম্যাচ" এর জন্য "সহায়ক সাহায্যকারী" লেখার পরিবর্তে যা আপনার সমস্ত কিছু অ্যাক্সেস করে PredicateList, প্রায়শই সম্ভবত ভবিষ্যদ্বাণী তালিকা থেকে কোনও সদস্য বা দু'জনকে কিছুটা সাধারণীকৃত ফাংশনে পাস করা সম্ভব হবে যার অ্যাক্সেসের প্রয়োজন নেই often প্রত্যেকটি ব্যক্তিগত সদস্য PredicateListএবং প্রায়শই সেই অভ্যন্তরীণ কার্যক্রমে আরও স্পষ্টতর, আরও সাধারণীকরণের নাম এবং উদ্দেশ্য এবং সেইসাথে "হাইজাইটসাইট পুনরায় ব্যবহারের" আরও সুযোগের ঝোঁক আসে।
ড্রাগন এনার্জি
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.