এই নির্দেশিকাটি শক্তিশালী, উচ্চ-মানের অ্যাপ তৈরির জন্য সর্বোত্তম অনুশীলন এবং প্রস্তাবিত আর্কিটেকচারকে অন্তর্ভুক্ত করে।
মোবাইল অ্যাপ ব্যবহারকারীর অভিজ্ঞতা
একটি সাধারণ অ্যান্ড্রয়েড অ্যাপে অ্যাক্টিভিটি , টুকরো , পরিষেবা , বিষয়বস্তু প্রদানকারী এবং ব্রডকাস্ট রিসিভার সহ একাধিক অ্যাপের উপাদান থাকে। আপনি এই অ্যাপের বেশিরভাগ উপাদান আপনার অ্যাপ ম্যানিফেস্টে ঘোষণা করেন। 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 নমুনাগুলি ভাল অ্যাপ আর্কিটেকচার প্রদর্শন করে৷ অনুশীলনে এই নির্দেশিকা দেখতে তাদের অন্বেষণ করুন:
This template is compatible with the latest stable version of Android Studio. These samples showcase different architectural approaches to developing Android apps. In its different branches you'll find the same app (a TODO app) implemented with small differences.
In this branch you'll find:
User Interface built with Jetpack This template is compatible with the latest stable version of Android Studio. Jetcaster is a sample podcast app, built with Jetpack Compose. The goal of the sample is to showcase building with Compose across multiple form factors (mobile, TV, and Wear) and full featured architecture.
To try out this sample app, use the latest Learn how this app was designed and built in the design case study, architecture learning journey and modularization learning journey.
This is the repository for the Now in Android app. It is a work in progress 🚧.
Now in Android is a fully functionalArchitecture starter template (multi-module)
Architecture
Architecture starter template (single module)
Jetcaster sample 🎙️
Now in Android App