এই নির্দেশিকাটি শক্তিশালী, উচ্চ-মানের অ্যাপ তৈরির জন্য সর্বোত্তম অনুশীলন এবং প্রস্তাবিত আর্কিটেকচারকে অন্তর্ভুক্ত করে।
মোবাইল অ্যাপ ব্যবহারকারীর অভিজ্ঞতা
একটি সাধারণ অ্যান্ড্রয়েড অ্যাপে অ্যাক্টিভিটি , টুকরো , পরিষেবা , বিষয়বস্তু প্রদানকারী এবং ব্রডকাস্ট রিসিভার সহ একাধিক অ্যাপের উপাদান থাকে। আপনি এই অ্যাপের বেশিরভাগ উপাদান আপনার অ্যাপ ম্যানিফেস্টে ঘোষণা করেন। Android OS তারপরে ডিভাইসের সামগ্রিক ব্যবহারকারীর অভিজ্ঞতার সাথে আপনার অ্যাপকে কীভাবে সংহত করতে হবে তা সিদ্ধান্ত নিতে এই ফাইলটি ব্যবহার করে। প্রদত্ত যে একটি সাধারণ Android অ্যাপে একাধিক উপাদান থাকতে পারে এবং ব্যবহারকারীরা প্রায়শই অল্প সময়ের মধ্যে একাধিক অ্যাপের সাথে ইন্টারঅ্যাক্ট করে, অ্যাপগুলিকে বিভিন্ন ধরনের ব্যবহারকারী-চালিত ওয়ার্কফ্লো এবং কাজের সাথে মানিয়ে নিতে হবে।
মনে রাখবেন যে মোবাইল ডিভাইসগুলিও সংস্থান-সীমাবদ্ধ, তাই যে কোনও সময়, অপারেটিং সিস্টেম নতুনগুলির জন্য জায়গা তৈরি করতে কিছু অ্যাপ প্রক্রিয়াগুলিকে মেরে ফেলতে পারে৷
এই পরিবেশের অবস্থার পরিপ্রেক্ষিতে, আপনার অ্যাপের উপাদানগুলি পৃথকভাবে চালু করা এবং অর্ডারের বাইরে থাকা সম্ভব এবং অপারেটিং সিস্টেম বা ব্যবহারকারী যে কোনও সময় সেগুলিকে ধ্বংস করতে পারে৷ যেহেতু এই ইভেন্টগুলি আপনার নিয়ন্ত্রণে নেই, তাই আপনার অ্যাপ্লিকেশন উপাদানগুলিতে কোনও অ্যাপ্লিকেশন ডেটা বা স্টেট সংরক্ষণ করা বা মেমরিতে রাখা উচিত নয় এবং আপনার অ্যাপ উপাদানগুলি একে অপরের উপর নির্ভর করা উচিত নয়৷
সাধারণ স্থাপত্য নীতি
আপনি যদি অ্যাপ্লিকেশন ডেটা এবং স্টেট সঞ্চয় করার জন্য অ্যাপের উপাদানগুলি ব্যবহার না করেন, তাহলে আপনি কীভাবে আপনার অ্যাপটি ডিজাইন করবেন?
অ্যান্ড্রয়েড অ্যাপ্লিকেশানগুলি আকারে বড় হওয়ার সাথে সাথে একটি আর্কিটেকচার সংজ্ঞায়িত করা গুরুত্বপূর্ণ যা অ্যাপটিকে স্কেল করার অনুমতি দেয়, অ্যাপের দৃঢ়তা বাড়ায় এবং অ্যাপটিকে পরীক্ষা করা সহজ করে।
একটি অ্যাপ আর্কিটেকচার অ্যাপের অংশগুলির মধ্যে সীমানা নির্ধারণ করে এবং প্রতিটি অংশের দায়িত্ব থাকা উচিত। উপরে উল্লিখিত চাহিদাগুলি পূরণ করার জন্য, আপনাকে কয়েকটি নির্দিষ্ট নীতি অনুসরণ করার জন্য আপনার অ্যাপ আর্কিটেকচার ডিজাইন করা উচিত।
উদ্বেগ বিচ্ছেদ
অনুসরণ করার সবচেয়ে গুরুত্বপূর্ণ নীতি হল উদ্বেগের বিচ্ছেদ । আপনার সমস্ত কোড একটি Activity
বা একটি Fragment
লেখা একটি সাধারণ ভুল। এই UI-ভিত্তিক ক্লাসগুলিতে শুধুমাত্র যুক্তি থাকা উচিত যা UI এবং অপারেটিং সিস্টেমের মিথস্ক্রিয়া পরিচালনা করে। এই ক্লাসগুলিকে যতটা সম্ভব চর্বিহীন রেখে, আপনি উপাদান জীবনচক্র সম্পর্কিত অনেক সমস্যা এড়াতে পারেন এবং এই ক্লাসগুলির পরীক্ষাযোগ্যতা উন্নত করতে পারেন।
মনে রাখবেন যে আপনি Activity
এবং Fragment
এর বাস্তবায়নের মালিক নন; বরং, এগুলি শুধুমাত্র আঠালো ক্লাস যা Android OS এবং আপনার অ্যাপের মধ্যে চুক্তির প্রতিনিধিত্ব করে৷ ব্যবহারকারীর মিথস্ক্রিয়া বা কম মেমরির মতো সিস্টেমের অবস্থার কারণে OS যেকোন সময় সেগুলিকে ধ্বংস করতে পারে। একটি সন্তোষজনক ব্যবহারকারীর অভিজ্ঞতা এবং আরও পরিচালনাযোগ্য অ্যাপ রক্ষণাবেক্ষণের অভিজ্ঞতা প্রদান করতে, তাদের উপর আপনার নির্ভরতা কমিয়ে আনা সর্বোত্তম।
ডেটা মডেল থেকে ড্রাইভ UI
আরেকটি গুরুত্বপূর্ণ নীতি হল যে আপনার UI ডাটা মডেল থেকে চালিত করা উচিত, বিশেষত স্থায়ী মডেলগুলি। ডেটা মডেলগুলি একটি অ্যাপের ডেটা উপস্থাপন করে। তারা আপনার অ্যাপের UI উপাদান এবং অন্যান্য উপাদান থেকে স্বাধীন। এর মানে হল যে তারা UI এবং অ্যাপ কম্পোনেন্ট লাইফসাইকেলের সাথে আবদ্ধ নয়, তবে OS যখন মেমরি থেকে অ্যাপের প্রক্রিয়াটি সরানোর সিদ্ধান্ত নেয় তখনও ধ্বংস হয়ে যাবে।
ক্রমাগত মডেল নিম্নলিখিত কারণগুলির জন্য আদর্শ:
আপনার ব্যবহারকারীরা ডেটা হারাবেন না যদি Android OS সম্পদ খালি করার জন্য আপনার অ্যাপটি ধ্বংস করে দেয়।
নেটওয়ার্ক কানেকশন ফ্ল্যাকি বা উপলব্ধ না থাকলে আপনার অ্যাপটি কাজ করতে থাকে।
আপনি যদি ডেটা মডেল ক্লাসের উপর আপনার অ্যাপ আর্কিটেকচারের ভিত্তি করে থাকেন, তাহলে আপনি আপনার অ্যাপটিকে আরও পরীক্ষাযোগ্য এবং শক্তিশালী করে তুলবেন।
সত্যের একক উৎস
যখন আপনার অ্যাপে একটি নতুন ডেটা টাইপ সংজ্ঞায়িত করা হয়, তখন আপনার এটিতে একটি সিঙ্গেল সোর্স অফ ট্রুথ (SSOT) বরাদ্দ করা উচিত। SSOT সেই ডেটার মালিক , এবং শুধুমাত্র SSOT এটিকে সংশোধন বা পরিবর্তন করতে পারে৷ এটি অর্জনের জন্য, SSOT একটি অপরিবর্তনীয় টাইপ ব্যবহার করে ডেটা প্রকাশ করে, এবং ডেটা পরিবর্তন করার জন্য, SSOT ফাংশনগুলি প্রকাশ করে বা ইভেন্টগুলি গ্রহণ করে যা অন্য ধরনের কল করতে পারে।
এই প্যাটার্নটি একাধিক সুবিধা নিয়ে আসে:
- এটি একটি নির্দিষ্ট ধরণের ডেটাতে সমস্ত পরিবর্তনকে এক জায়গায় কেন্দ্রীভূত করে।
- এটি ডেটাকে সুরক্ষিত করে যাতে অন্য প্রকারগুলি এটির সাথে হস্তক্ষেপ করতে না পারে৷
- এটি ডেটাতে পরিবর্তনগুলিকে আরও সনাক্তযোগ্য করে তোলে। সুতরাং, বাগগুলি সনাক্ত করা সহজ।
একটি অফলাইন-প্রথম অ্যাপ্লিকেশনে, অ্যাপ্লিকেশন ডেটার জন্য সত্যের উৎস সাধারণত একটি ডাটাবেস। অন্য কিছু ক্ষেত্রে, সত্যের উৎস হতে পারে একটি ViewModel বা এমনকি UI।
একমুখী ডেটা প্রবাহ
সত্য নীতির একক উৎস প্রায়শই ইউনিডাইরেকশনাল ডেটা ফ্লো (UDF) প্যাটার্ন সহ আমাদের গাইডগুলিতে ব্যবহৃত হয়। UDF-এ, রাষ্ট্র শুধুমাত্র একটি দিকে প্রবাহিত হয়। যে ঘটনাগুলি ডেটা প্রবাহকে বিপরীত দিকে পরিবর্তন করে।
অ্যান্ড্রয়েডে, স্টেট বা ডেটা সাধারণত উচ্চ-স্কোপযুক্ত ধরণের শ্রেণিবিন্যাসের থেকে নিম্ন-স্কোপের দিকে প্রবাহিত হয়। ইভেন্টগুলি সাধারণত নিম্ন-স্কোপের ধরন থেকে শুরু হয় যতক্ষণ না তারা সংশ্লিষ্ট ডেটা টাইপের জন্য SSOT-এ পৌঁছায়। উদাহরণস্বরূপ, অ্যাপ্লিকেশন ডেটা সাধারণত ডেটা উত্স থেকে UI এ প্রবাহিত হয়। ব্যবহারকারীর ইভেন্টগুলি যেমন বোতাম টিপে UI থেকে SSOT-তে প্রবাহিত হয় যেখানে অ্যাপ্লিকেশন ডেটা পরিবর্তন করা হয় এবং একটি অপরিবর্তনীয় প্রকারে প্রকাশ করা হয়।
এই প্যাটার্নটি ডেটা সামঞ্জস্যের আরও ভাল গ্যারান্টি দেয়, ত্রুটির প্রবণতা কম, ডিবাগ করা সহজ এবং SSOT প্যাটার্নের সমস্ত সুবিধা নিয়ে আসে।
প্রস্তাবিত অ্যাপ আর্কিটেকচার
প্রস্তাবিত সেরা অনুশীলনগুলি অনুসরণ করে কীভাবে আপনার অ্যাপ গঠন করতে হয় তা এই বিভাগটি দেখায়।
পূর্ববর্তী বিভাগে উল্লিখিত সাধারণ স্থাপত্য নীতিগুলি বিবেচনা করে, প্রতিটি অ্যাপ্লিকেশনের কমপক্ষে দুটি স্তর থাকা উচিত:
- UI স্তর যা স্ক্রিনে অ্যাপ্লিকেশন ডেটা প্রদর্শন করে।
- ডেটা স্তর যা আপনার অ্যাপের ব্যবসায়িক যুক্তি ধারণ করে এবং অ্যাপ্লিকেশন ডেটা প্রকাশ করে।
আপনি UI এবং ডেটা স্তরগুলির মধ্যে মিথস্ক্রিয়াগুলিকে সহজ করতে এবং পুনরায় ব্যবহার করতে ডোমেন স্তর নামে একটি অতিরিক্ত স্তর যুক্ত করতে পারেন।

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

এই স্তর সম্পর্কে আরও জানতে, UI স্তর পৃষ্ঠাটি দেখুন।
ডাটা লেয়ার
একটি অ্যাপের ডেটা লেয়ারে ব্যবসায়িক যুক্তি থাকে। ব্যবসায়িক যুক্তি হল যা আপনার অ্যাপকে মূল্য দেয়—এটি নিয়ম দিয়ে তৈরি যা নির্ধারণ করে যে আপনার অ্যাপ কীভাবে ডেটা তৈরি করে, সঞ্চয় করে এবং পরিবর্তন করে।
ডেটা স্তরটি সংগ্রহস্থল দিয়ে তৈরি যে প্রতিটিতে শূন্য থেকে অনেকগুলি ডেটা উত্স থাকতে পারে। আপনি আপনার অ্যাপে পরিচালনা করেন এমন প্রতিটি ভিন্ন ধরণের ডেটার জন্য আপনার একটি সংগ্রহস্থল শ্রেণী তৈরি করা উচিত। উদাহরণস্বরূপ, আপনি চলচ্চিত্র সম্পর্কিত ডেটার জন্য একটি MoviesRepository
ক্লাস বা অর্থপ্রদান সম্পর্কিত ডেটার জন্য একটি PaymentsRepository
ক্লাস তৈরি করতে পারেন।

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

এই স্তরের ক্লাসগুলিকে সাধারণত ইউজ কেস বা ইন্টারঅ্যাক্টর বলা হয়। প্রতিটি ব্যবহারের ক্ষেত্রে একটি একক কার্যকারিতার উপর দায়িত্ব থাকা উচিত। উদাহরণস্বরূপ, আপনার অ্যাপের একটি GetTimeZoneUseCase
ক্লাস থাকতে পারে যদি একাধিক ViewModels স্ক্রিনে সঠিক বার্তা প্রদর্শনের জন্য সময় অঞ্চলের উপর নির্ভর করে।
এই স্তর সম্পর্কে আরও জানতে, ডোমেন স্তর পৃষ্ঠাটি দেখুন।
উপাদানগুলির মধ্যে নির্ভরতা পরিচালনা করুন
আপনার অ্যাপের ক্লাসগুলি সঠিকভাবে কাজ করার জন্য অন্যান্য ক্লাসের উপর নির্ভর করে। আপনি একটি নির্দিষ্ট শ্রেণীর নির্ভরতা সংগ্রহ করতে নিম্নলিখিত নকশা নিদর্শন ব্যবহার করতে পারেন:
- ডিপেনডেন্সি ইনজেকশন (DI) : ডিপেনডেন্সি ইনজেকশন শ্রেণীগুলিকে তাদের নির্মান না করেই তাদের নির্ভরতা নির্ধারণ করতে দেয়। রানটাইমে, অন্য শ্রেণী এই নির্ভরতা প্রদানের জন্য দায়ী।
- পরিষেবা লোকেটার : পরিষেবা লোকেটার প্যাটার্ন একটি রেজিস্ট্রি প্রদান করে যেখানে ক্লাসগুলি তাদের নির্মাণের পরিবর্তে তাদের নির্ভরতা পেতে পারে।
এই নিদর্শনগুলি আপনাকে আপনার কোড স্কেল করার অনুমতি দেয় কারণ তারা কোড নকল না করে বা জটিলতা যোগ না করে নির্ভরতা পরিচালনার জন্য স্পষ্ট নিদর্শন সরবরাহ করে। উপরন্তু, এই নিদর্শনগুলি আপনাকে পরীক্ষা এবং উত্পাদন বাস্তবায়নের মধ্যে দ্রুত স্যুইচ করার অনুমতি দেয়।
আমরা নির্ভরতা ইনজেকশন প্যাটার্ন অনুসরণ করার এবং Android অ্যাপে হিল্ট লাইব্রেরি ব্যবহার করার পরামর্শ দিই। হিল্ট স্বয়ংক্রিয়ভাবে নির্ভরতা গাছে হেঁটে বস্তু তৈরি করে, নির্ভরতার উপর কম্পাইল-টাইম গ্যারান্টি প্রদান করে এবং অ্যান্ড্রয়েড ফ্রেমওয়ার্ক ক্লাসের জন্য নির্ভরতা পাত্র তৈরি করে।
সাধারণ সর্বোত্তম অনুশীলন
প্রোগ্রামিং একটি সৃজনশীল ক্ষেত্র, এবং অ্যান্ড্রয়েড অ্যাপ তৈরি করা একটি ব্যতিক্রম নয়। একটি সমস্যা সমাধানের অনেক উপায় আছে; আপনি একাধিক ক্রিয়াকলাপ বা টুকরোগুলির মধ্যে ডেটা যোগাযোগ করতে পারেন, দূরবর্তী ডেটা পুনরুদ্ধার করতে পারেন এবং অফলাইন মোডের জন্য স্থানীয়ভাবে এটি চালিয়ে যেতে পারেন, বা অতুচ্ছ অ্যাপগুলির মুখোমুখি হওয়া অন্যান্য সাধারণ পরিস্থিতিগুলির একটি সংখ্যা পরিচালনা করতে পারেন৷
যদিও নিম্নলিখিত সুপারিশগুলি বাধ্যতামূলক নয়, বেশিরভাগ ক্ষেত্রেই সেগুলি অনুসরণ করা আপনার কোড বেসকে আরও শক্তিশালী, পরীক্ষাযোগ্য এবং দীর্ঘমেয়াদে বজায় রাখার যোগ্য করে তোলে:
অ্যাপের উপাদানগুলিতে ডেটা সংরক্ষণ করবেন না।
ডেটার উৎস হিসেবে আপনার অ্যাপের এন্ট্রি পয়েন্ট—যেমন কার্যকলাপ, পরিষেবা এবং ব্রডকাস্ট রিসিভারগুলিকে মনোনীত করা এড়িয়ে চলুন। পরিবর্তে, সেই এন্ট্রি পয়েন্টের সাথে প্রাসঙ্গিক ডেটার উপসেট পুনরুদ্ধার করতে তাদের শুধুমাত্র অন্যান্য উপাদানগুলির সাথে সমন্বয় করা উচিত। প্রতিটি অ্যাপ্লিকেশন উপাদান বরং স্বল্পস্থায়ী, ব্যবহারকারীর তাদের ডিভাইসের সাথে মিথস্ক্রিয়া এবং সিস্টেমের সামগ্রিক বর্তমান স্বাস্থ্যের উপর নির্ভর করে।
অ্যান্ড্রয়েড ক্লাসের উপর নির্ভরতা হ্রাস করুন।
আপনার অ্যাপের উপাদানগুলি শুধুমাত্র এমন ক্লাস হওয়া উচিত যা Android ফ্রেমওয়ার্ক SDK API যেমন Context
বা Toast
উপর নির্ভর করে। আপনার অ্যাপের অন্যান্য ক্লাসগুলিকে তাদের থেকে দূরে সরিয়ে রাখা পরীক্ষাযোগ্যতার সাথে সাহায্য করে এবং আপনার অ্যাপের মধ্যে সংযোগ কমায়।
আপনার অ্যাপে বিভিন্ন মডিউলের মধ্যে দায়িত্বের সু-সংজ্ঞায়িত সীমানা তৈরি করুন।
উদাহরণস্বরূপ, আপনার কোড বেসের একাধিক ক্লাস বা প্যাকেজগুলিতে নেটওয়ার্ক থেকে ডেটা লোড করে এমন কোডটি ছড়িয়ে দেবেন না। একইভাবে, একই ক্লাসে একাধিক অসম্পর্কিত দায়িত্ব- যেমন ডেটা ক্যাশিং এবং ডেটা বাইন্ডিং-কে সংজ্ঞায়িত করবেন না। প্রস্তাবিত অ্যাপ আর্কিটেকচার অনুসরণ করলে এটি আপনাকে সাহায্য করবে।
প্রতিটি মডিউল থেকে যতটা সম্ভব কম প্রকাশ করুন।
উদাহরণস্বরূপ, একটি শর্টকাট তৈরি করতে প্রলুব্ধ হবেন না যা একটি মডিউল থেকে অভ্যন্তরীণ বাস্তবায়নের বিশদ প্রকাশ করে। আপনি স্বল্পমেয়াদে কিছুটা সময় লাভ করতে পারেন, তবে আপনার কোডবেস বিকশিত হওয়ার সাথে সাথে আপনি অনেকবার প্রযুক্তিগত ঋণ বহন করতে পারেন।
আপনার অ্যাপ্লিকেশানের অনন্য মূলে ফোকাস করুন যাতে এটি অন্যান্য অ্যাপ থেকে আলাদা হয়।
একই বয়লারপ্লেট কোড বারবার লিখে চাকাটিকে পুনরায় উদ্ভাবন করবেন না। পরিবর্তে, আপনার অ্যাপটিকে কী অনন্য করে তোলে তার উপর আপনার সময় এবং শক্তি ফোকাস করুন এবং জেটপ্যাক লাইব্রেরি এবং অন্যান্য প্রস্তাবিত লাইব্রেরিগুলিকে পুনরাবৃত্তিমূলক বয়লারপ্লেট পরিচালনা করতে দিন।
কীভাবে আপনার অ্যাপের প্রতিটি অংশকে বিচ্ছিন্নভাবে পরীক্ষাযোগ্য করা যায় তা বিবেচনা করুন।
উদাহরণস্বরূপ, নেটওয়ার্ক থেকে ডেটা আনার জন্য একটি সু-সংজ্ঞায়িত API থাকা মডিউলটি পরীক্ষা করা সহজ করে তোলে যা স্থানীয় ডাটাবেসে সেই ডেটা টিকে থাকে। পরিবর্তে, আপনি যদি এই দুটি মডিউল থেকে যুক্তি এক জায়গায় মিশ্রিত করেন, বা আপনার পুরো কোড বেস জুড়ে আপনার নেটওয়ার্কিং কোড বিতরণ করেন, তাহলে এটি কার্যকরভাবে পরীক্ষা করা অনেক বেশি কঠিন - যদি অসম্ভব না হয় - হয়ে ওঠে।
ধরনগুলি তাদের সঙ্গতি নীতির জন্য দায়ী৷
যদি একটি টাইপ দীর্ঘ-চলমান ব্লকিং কাজ সম্পাদন করে, তবে সেই গণনাটিকে সঠিক থ্রেডে নিয়ে যাওয়ার জন্য দায়ী হওয়া উচিত। সেই নির্দিষ্ট টাইপটি জানে যে এটি কী ধরনের গণনা করছে এবং কোন থ্রেডে এটি কার্যকর করা উচিত। প্রকারগুলি প্রধান-নিরাপদ হওয়া উচিত, যার অর্থ তারা ব্লক না করেই মূল থ্রেড থেকে কল করা নিরাপদ৷
যতটা সম্ভব প্রাসঙ্গিক এবং নতুন ডেটা বজায় রাখুন।
এইভাবে, ব্যবহারকারীরা তাদের ডিভাইস অফলাইন মোডে থাকা অবস্থায়ও আপনার অ্যাপের কার্যকারিতা উপভোগ করতে পারে। মনে রাখবেন যে আপনার সমস্ত ব্যবহারকারী ধ্রুবক, উচ্চ-গতির সংযোগ উপভোগ করেন না—এবং এমনকি যদি তারা করেন, তারা জনাকীর্ণ জায়গায় খারাপ অভ্যর্থনা পেতে পারেন।
স্থাপত্যের সুবিধা
আপনার অ্যাপে একটি ভাল আর্কিটেকচার প্রয়োগ করা প্রকল্প এবং প্রকৌশল দলগুলির জন্য অনেক সুবিধা নিয়ে আসে:
- এটি সামগ্রিক অ্যাপের রক্ষণাবেক্ষণযোগ্যতা, গুণমান এবং দৃঢ়তা উন্নত করে।
- এটি অ্যাপটিকে স্কেল করার অনুমতি দেয়। ন্যূনতম কোড দ্বন্দ্ব সহ আরও বেশি লোক এবং আরও দল একই কোডবেসে অবদান রাখতে পারে।
- এটা অনবোর্ডিং সঙ্গে সাহায্য করে. যেহেতু আর্কিটেকচার আপনার প্রজেক্টে ধারাবাহিকতা নিয়ে আসে, তাই দলের নতুন সদস্যরা দ্রুত গতিতে উঠতে পারে এবং কম সময়ে আরও দক্ষ হতে পারে।
- এটি পরীক্ষা করা সহজ। একটি ভাল আর্কিটেকচার সহজ প্রকারকে উৎসাহিত করে যা সাধারণত পরীক্ষা করা সহজ।
- বাগগুলি ভালভাবে সংজ্ঞায়িত প্রক্রিয়াগুলির সাথে পদ্ধতিগতভাবে তদন্ত করা যেতে পারে।
আর্কিটেকচারে বিনিয়োগ আপনার ব্যবহারকারীদের উপর সরাসরি প্রভাব ফেলে। তারা আরও বেশি স্থিতিশীল অ্যাপ্লিকেশন থেকে উপকৃত হয়, এবং আরও বেশি উত্পাদনশীল প্রকৌশল দলের কারণে আরও বৈশিষ্ট্যগুলি। যাইহোক, আর্কিটেকচারের জন্য একটি আপ-ফ্রন্ট টাইম বিনিয়োগও প্রয়োজন। আপনার বাকি কোম্পানির কাছে এই সময়টিকে ন্যায্যতা দিতে আপনাকে সাহায্য করার জন্য, এই কেস স্টাডিগুলি দেখুন যেখানে অন্যান্য কোম্পানিগুলি তাদের অ্যাপে একটি ভাল আর্কিটেকচার থাকার সময় তাদের সাফল্যের গল্পগুলি ভাগ করে।
নমুনা
নিম্নলিখিত Google নমুনাগুলি ভাল অ্যাপ আর্কিটেকচার প্রদর্শন করে৷ অনুশীলনে এই নির্দেশিকা দেখতে তাদের অন্বেষণ করুন:
NEW STATE Mobile 是 Krafton 的一款大逃杀游戏于 2021 年 11 月面向全球发布,在发布后的第一个月便获得了超过 4500 万次下载。KRAFTON, Inc. 是一个由多个独立的游戏开发工作室组成的联合公司,旨在为全球游戏玩家打造富有吸引力的创新娱乐体验。该公司包括 PUBG Studio、Bluehole Studio、Striking Distance Studio、RisingWings、Dreamotion 和 Unknown新 STATE Mobile 利用 Android GPU 检查器将 GPU 使用量降低了 22%
এখন দেখানোর মতো কোনও সাজেশন নেই।
আপনার Google অ্যাকাউন্টে সাইন-ইন করে দেখুন।