जावा वर्चुअल मशीन - कचरा संग्रह

जावा ऑब्जेक्ट का जीवनचक्र JVM द्वारा प्रबंधित किया जाता है। एक बार प्रोग्रामर द्वारा कोई ऑब्जेक्ट बनाए जाने के बाद, हमें उसके शेष जीवनचक्र के बारे में चिंता करने की आवश्यकता नहीं है। JVM स्वचालित रूप से उन वस्तुओं को खोजेगा जो अब उपयोग में नहीं हैं और ढेर से अपनी मेमोरी को पुनः प्राप्त करते हैं।

कचरा संग्रहण एक बड़ा ऑपरेशन है जो जेवीएम करता है और हमारी जरूरतों के लिए इसे ट्यूनिंग करने से हमारे आवेदन को बड़े पैमाने पर प्रदर्शन को बढ़ावा मिल सकता है। विभिन्न प्रकार के कचरा संग्रह एल्गोरिदम हैं जो आधुनिक जेवीएम द्वारा प्रदान किए जाते हैं। हमें अपने एप्लिकेशन की जरूरतों के बारे में पता होना चाहिए कि किस एल्गोरिदम का उपयोग करना है।

आप किसी ऑब्जेक्ट को जावा में प्रोग्रामेटिक रूप से डील नहीं कर सकते हैं, जैसे आप सी और सी ++ जैसी गैर-जीसी भाषाओं में कर सकते हैं। इसलिए, आपके पास जावा में झूलने वाले संदर्भ नहीं हो सकते हैं। हालाँकि, आपके पास अशक्त संदर्भ (संदर्भ जो कि मेमोरी के एक क्षेत्र को संदर्भित करते हैं जहां JVM कभी भी वस्तुओं को संग्रहीत नहीं करेगा)। जब भी एक शून्य संदर्भ का उपयोग किया जाता है, तो JVM एक NullPointerException को फेंकता है।

ध्यान दें कि जब तक जीसी के लिए जावा कार्यक्रमों में मेमोरी लीक का पता लगाना दुर्लभ है, वे ऐसा करते हैं। हम इस अध्याय के अंत में एक मेमोरी लीक बनाएंगे।

आधुनिक जीवीएम में निम्नलिखित जीसी का उपयोग किया जाता है

  • सीरियल कलेक्टर
  • थ्रूपुट कलेक्टर
  • सीएमएस कलेक्टर
  • जी 1 कलेक्टर

उपर्युक्त एल्गोरिदम में से प्रत्येक एक ही कार्य करता है - उन वस्तुओं को ढूंढना जो अब उपयोग में नहीं हैं और स्मृति को पुनः प्राप्त करना है जो वे ढेर में रहते हैं। इसमें से एक भोली दृष्टिकोण संदर्भों की संख्या की गणना करने के लिए होगा जो प्रत्येक वस्तु के पास है और जैसे ही संदर्भ 0 की संख्या से मुक्त हो जाता है (इसे संदर्भ गिनती के रूप में भी जाना जाता है)। यह भोला क्यों है? एक परिपत्र लिंक्ड सूची पर विचार करें। इसके प्रत्येक नोड का एक संदर्भ होगा, लेकिन संपूर्ण ऑब्जेक्ट को कहीं से संदर्भित नहीं किया जा रहा है, और इसे मुक्त किया जाना चाहिए, आदर्श रूप से।

जेवीएम न केवल मेमोरी को मुक्त करता है, बल्कि छोटे मेमोरी चक को भी बड़े लोगों में शामिल करता है। यह मेमोरी विखंडन को रोकने के लिए किया जाता है।

एक साधारण नोट पर, एक विशिष्ट जीसी एल्गोरिथ्म निम्नलिखित गतिविधियां करता है -

  • अप्रयुक्त वस्तुओं का पता लगाना
  • स्मृति को मुक्त करना जो वे ढेर में रहते हैं
  • टुकड़े टुकड़े करना

जीसी को आवेदन थ्रेड्स को रोकना पड़ता है जबकि यह चल रहा है। ऐसा इसलिए है क्योंकि जब यह चलता है तो यह वस्तुओं को इधर-उधर कर देता है, और इसलिए, उन वस्तुओं का उपयोग नहीं किया जा सकता है। इस तरह के स्टॉप को 'स्टॉप-द-वर्ल्ड पॉज़ कहा जाता है और इन पॉज़ की आवृत्ति और अवधि को कम करना, जो कि हमारे जीसी को ट्यून करते समय हमारा उद्देश्य है।

मेमोरी कोलेसिंग

मेमोरी कोलेसिंग का एक सरल प्रदर्शन नीचे दिखाया गया है

छायांकित भाग ऐसी वस्तुएँ हैं जिन्हें मुक्त करने की आवश्यकता है। इसके बाद भी जब सभी स्थान पुन: प्राप्त होते हैं, हम केवल अधिकतम आकार = 75Kb की एक वस्तु आवंटित कर सकते हैं। यह तब भी होता है जब हमारे पास नीचे दिखाए गए अनुसार 200Kb खाली जगह होती है