ওহে! আজকের পাঠটি
প্রথমত, আসুন দেখি নতুন উপাদান যোগ করলে কেমন লাগে। ব্যবসার প্রথম ক্রম হল অভ্যন্তরীণ অ্যারের অভ্যন্তরীণ অ্যারেতে পর্যাপ্ত জায়গা আছে কিনা এবং আরও একটি উপাদান ফিট হবে কিনা তা পরীক্ষা করা। যদি স্থান থাকে, তাহলে তালিকার শেষে নতুন উপাদান যোগ করা হয়। যখন আমরা "শেষ পর্যন্ত" বলি, তখন আমরা অ্যারের শেষ অবস্থান বোঝাই না (এটি অদ্ভুত হবে)। আমরা শেষ বর্তমান উপাদান অনুসরণ অবস্থান মানে. এর সূচক হবে
এটা যথেষ্ট পরিষ্কার. যদি আমরা মাঝখানে, অর্থাৎ অন্যান্য উপাদানের মধ্যে সন্নিবেশ করি তাহলে কি হবে?
আমাদের নতুন উপাদানটি তার জায়গায় সন্নিবেশ করা হয়েছে। পূর্ববর্তী উপাদান (bugatti) ইতিমধ্যে একটি নতুন অবস্থান থেকে কপি করা হয়েছে.
এখন দেখা যাক কিভাবে এই প্রক্রিয়াটি ঘটবে যদি অ্যারেতে নতুন উপাদান ঢোকানোর জায়গা না থাকে।
স্বাভাবিকভাবেই, পর্যাপ্ত জায়গা আছে কিনা তা দেখার জন্য প্রথমে একটি পরীক্ষা করা হয়। যদি পর্যাপ্ত রুম না থাকে, তাহলে এর ভিতরে একটি নতুন অ্যারে তৈরি করা হয়
পুরানো অ্যারে আবর্জনা সংগ্রহকারী দ্বারা মুছে ফেলা হবে, এবং শুধুমাত্র নতুন, প্রসারিত অ্যারে থাকবে। এখন একটি নতুন উপাদান জন্য জায়গা আছে. আমরা অবস্থান 3 এ সন্নিবেশ করছি, যা দখল করা হয়. এখন পরিচিত পদ্ধতি শুরু হয়। সূচক 3 থেকে শুরু করে সমস্ত উপাদান ডানদিকে এক অবস্থানে স্থানান্তরিত হয় এবং নতুন উপাদানটি শান্তভাবে যোগ করা হয়।
এবং সন্নিবেশ করা হয়! এবং আমরা সন্নিবেশ সঙ্গে সম্পন্ন করছি. এখন আইটেম অপসারণ সম্পর্কে কথা বলা যাক . আপনি মনে রাখবেন যে অ্যারেগুলির সাথে কাজ করার সময় আমরা একটি সমস্যায় পড়েছিলাম: উপাদানগুলি সরানো একটি অ্যারেতে "গর্ত" তৈরি করে।প্রতিটি অপসারণের সাথে, এবং এই পরিবর্তনটি সম্পাদন করার জন্য আমাদের প্রতিবার আমাদের নিজস্ব কোড লিখতে হয়েছিল। ArrayList একই নীতি অনুসরণ করে, কিন্তু এটি ইতিমধ্যে এই প্রক্রিয়াটি প্রয়োগ করে।
এটি এইভাবে দেখায়:
এবং শেষ পর্যন্ত আমরা যা চাই তা পাই:
উপাদানটি
প্রোগ্রামটি চলার সাথে সাথে আমরা 77টি উপাদান সরিয়ে ফেলি, তাই শুধুমাত্র 11টি অবশিষ্ট থাকে:
আপনি কি ইতিমধ্যেই অনুমান করেছেন সমস্যাটি কী? বুঝেছ, স্মৃতির অদক্ষ ব্যবহার! আমরা এখানে শুধুমাত্র 11টি অবস্থান ব্যবহার করছি, কিন্তু আমরা 88টি উপাদানের জন্য মেমরি বরাদ্দ করেছি। এটি আমাদের প্রয়োজনের চেয়ে 8 গুণ বেশি! এই ক্ষেত্রে, আমরা
এখন আমরা যতটুকু মেমরি প্রয়োজন ততটুকুই বরাদ্দ করেছি! :)
ArrayList
আগের পাঠের তুলনায় সহজ এবং কঠিন উভয়ই হবে।
![ছবিতে অ্যারেলিস্ট- ১](https://cdn.codegym.cc/images/article/bd72f32f-84a4-4872-8506-cc0f15be811f/512.jpeg)
ArrayList
এটি আরও কঠিন হবে কারণ আজ আমরা বিভিন্ন অপারেশনের সময় কী ঘটবে তা দেখতে এবং অধ্যয়ন করতে যাচ্ছি । অন্যদিকে, এই পাঠের প্রায় কোন কোড থাকবে না। এটি বেশিরভাগই ছবি এবং ব্যাখ্যা। আচ্ছা, চলুন যাই :) আপনি ইতিমধ্যেই জানেন, ArrayList
ভিতরে একটি সাধারণ অ্যারে রয়েছে, যা একটি ডেটা স্টোর হিসাবে কাজ করে। বেশিরভাগ ক্ষেত্রে, আমরা তালিকার সঠিক আকার নির্দিষ্ট করি না। কিন্তু অভ্যন্তরীণ অ্যারের কিছু আকার থাকতে হবে! এবং তাই এটা করে. এর ডিফল্ট আকার হল 10 ।
public static void main(String[] args) {
ArrayList<Car> cars = new ArrayList<>();
}
![ছবিতে অ্যারেলিস্ট - 2](https://cdn.codegym.cc/images/article/995c81c6-d02a-42ec-9721-c81c3f70e8c1/800.jpeg)
cars.size()
। আমাদের তালিকা বর্তমানে খালি ( cars.size() == 0
)। তদনুসারে, নতুন উপাদানটি 0 অবস্থানে যোগ করা হবে।
ArrayList<Car> cars = new ArrayList<>();
Car ferrari = new Car("Ferrari 360 Spider");
cars.add(ferrari);
![ছবিতে অ্যারেলিস্ট - 3](https://cdn.codegym.cc/images/article/bea45432-cdfb-48c8-b50c-9197b877ce79/800.jpeg)
public static void main(String[] args) {
ArrayList<Car> cars = new ArrayList<>();
Car ferrari = new Car("Ferrari 360 Spider");
Car bugatti = new Car("Bugatti Veyron");
Car lambo = new Car("Lamborghini Diablo");
Car ford = new Car("Ford Modneo");
cars.add(ferrari);
cars.add(bugatti);
cars.add(lambo);
cars.add(1, ford);// add ford to cell 1, which is already occupied
}
আবার, প্রথমে অ্যারেতে পর্যাপ্ত জায়গা আছে কিনা তা পরীক্ষা করে দেখুন। যদি পর্যাপ্ত স্থান থাকে, তাহলে উপাদানগুলি ডানদিকে সরানো হয় , যেখানে আমরা নতুন উপাদান সন্নিবেশ করছি সেই অবস্থান থেকে শুরু করে। আমরা অবস্থান 1 এ সন্নিবেশ করছি। অন্য কথায়, অবস্থান 3 থেকে উপাদানটি অবস্থান 4 এ, উপাদান 2 অবস্থান 3 এ এবং উপাদান 1 অবস্থান 2 এ অনুলিপি করা হয়েছে। তারপরে ![ছবিতে অ্যারেলিস্ট - 4টি](https://cdn.codegym.cc/images/article/d29292f8-43de-488d-9a42-dd76fafc1f3f/800.jpeg)
![ছবিতে অ্যারেলিস্ট - 5টি](https://cdn.codegym.cc/images/article/3c048a88-7fb5-4d37-9b64-c1062b547b9d/800.jpeg)
![ছবির অ্যারেলিস্ট- ৬টি](https://cdn.codegym.cc/images/article/f6f7ad5c-12bc-4736-896b-fd5b151a9b9b/800.jpeg)
ArrayList
যার মাপ পুরানো অ্যারের সাইজ 1.5 প্লাস 1 আমাদের ক্ষেত্রে, নতুন অ্যারের সাইজ হবে 16। বর্তমানের সমস্ত উপাদান অবিলম্বে সেখানে কপি করা হবে। ![ছবিতে অ্যারেলিস্ট - 7](https://cdn.codegym.cc/images/article/3661fa3e-117b-4c13-8653-70795cace07c/800.jpeg)
![ছবিতে অ্যারেলিস্ট - 8টি](https://cdn.codegym.cc/images/article/7db23aa9-6d50-4254-97fa-e0c5ae3cc6d1/800.jpeg)
![ছবিতে অ্যারেলিস্ট - 9](https://cdn.codegym.cc/images/article/c16de7b1-d4e6-44e4-95e7-705dd30627ec/800.jpeg)
![ছবিতে অ্যারেলিস্ট - 10টি](https://cdn.codegym.cc/images/article/a8b06b39-d4e4-4f8f-af8a-c00062cc02e3/800.jpeg)
![ছবিতে অ্যারেলিস্ট - 11](https://cdn.codegym.cc/images/article/afaeece9-9089-4778-a185-3495de62bd5e/800.jpeg)
lambo
সরানো হয়েছে। এখানে আমরা মাঝখান থেকে একটি উপাদান অপসারণ করেছি। স্পষ্টতই, তালিকার শেষ থেকে একটি উপাদান সরানো দ্রুততর, যেহেতু উপাদানটি অন্য সব স্থানান্তর করার প্রয়োজন ছাড়াই সরানো হয়। অভ্যন্তরীণ অ্যারের মাত্রা এবং এটি মেমরিতে কীভাবে সাজানো হয়েছে সে সম্পর্কে কিছুক্ষণের জন্য আবার কথা বলা যাক। একটি অ্যারে সম্প্রসারণ কিছু সম্পদ লাগে. তদনুসারে, একটি তৈরি করবেন নাArrayList
ডিফল্ট আকারের সাথে যদি আপনি নিশ্চিত হন যে এতে কমপক্ষে 100টি উপাদান থাকবে। আপনি 100 তম উপাদান সন্নিবেশ করার সময় অভ্যন্তরীণ অ্যারেটি 6 বার প্রসারিত করতে হবে এবং প্রতিবার সমস্ত উপাদান স্থানান্তর করতে হবে।
- 10টি উপাদান থেকে 16 পর্যন্ত
- 16টি উপাদান থেকে 25 পর্যন্ত
- 25 থেকে 38 পর্যন্ত
- 38 থেকে 58 পর্যন্ত
- 58 থেকে 88 পর্যন্ত
- 88 থেকে 133 পর্যন্ত (অর্থাৎ পুরানো অ্যারের টাইম 1.5 প্লাস 1)
ArrayList<Car> cars = new ArrayList<>(100);
এখন 100টি উপাদানের একটি অ্যারের জন্য মেমরি একবারে বরাদ্দ করা হবে, অ্যারেটিকে আরও দক্ষ করে তুলবে (এটি প্রসারিত করার প্রয়োজন হবে না)। এই কৌশলটির একটি উল্টো দিকও রয়েছে। যখন আপনি একটি থেকে বস্তুগুলি সরিয়ে দেন ArrayList
, তখন অভ্যন্তরীণ অ্যারের আকার স্বয়ংক্রিয়ভাবে হ্রাস পায় না। ধরুন আমাদের কাছে ArrayList
88টি উপাদানের একটি সম্পূর্ণ সম্পূর্ণ অভ্যন্তরীণ অ্যারে রয়েছে: ![ছবিতে অ্যারেলিস্ট - 12](https://cdn.codegym.cc/images/article/a2216fd0-f471-427d-8d04-69ad922d374c/800.jpeg)
![ছবিতে অ্যারেলিস্ট - 13টি](https://cdn.codegym.cc/images/article/6c3142cd-46c7-487a-965f-804f9350bdb7/800.jpeg)
ArrayList
ক্লাসের একটি বিশেষ পদ্ধতির সাহায্যে আমাদের মেমরি ব্যবহারকে অপ্টিমাইজ করতে পারি:trimToSize()
. এই পদ্ধতিটি অভ্যন্তরীণ অ্যারের দৈর্ঘ্যকে এটিতে বর্তমানে সংরক্ষিত উপাদানের সংখ্যায় "ছাঁটা" করে। ![ছবিতে অ্যারেলিস্ট - 14](https://cdn.codegym.cc/images/article/8203feaf-e474-485c-ad4c-b1205f6388b3/800.jpeg)
GO TO FULL VERSION