जवाबों:
ध्वज Xmx
एक जावा वर्चुअल मशीन (JVM) के लिए अधिकतम मेमोरी आवंटन पूल को Xms
निर्दिष्ट करता है , जबकि प्रारंभिक मेमोरी आवंटन पूल को निर्दिष्ट करता है।
इसका मतलब है कि आपका JVM Xms
मेमोरी की मात्रा के साथ शुरू किया जाएगा और मेमोरी की अधिकतम Xmx
मात्रा का उपयोग करने में सक्षम होगा । उदाहरण के लिए, नीचे की तरह एक जेवीएम शुरू करने से यह 256 एमबी मेमोरी के साथ शुरू होगा और प्रक्रिया को 2048 एमबी के पेज तक उपयोग करने की अनुमति देगा:
java -Xms256m -Xmx2048m
मेमोरी फ़्लैग को विभिन्न आकारों में भी निर्दिष्ट किया जा सकता है, जैसे किलोबाइट्स, मेगाबाइट्स, और इसी तरह।
-Xmx1024k
-Xmx512m
-Xmx8g
Xms
झंडा कोई डिफ़ॉल्ट मान है, और Xmx
आम तौर पर 256 एमबी का डिफ़ॉल्ट मान है। इन झंडों के लिए एक आम उपयोग तब होता है जब आप एक मुठभेड़ करते हैं java.lang.OutOfMemoryError
।
इन सेटिंग्स का उपयोग करते समय, ध्यान रखें कि ये सेटिंग्स JVM के हीप के लिए हैं , और यह कि JVM हीप को आवंटित आकार की तुलना में अधिक मेमोरी का उपयोग / कर सकता है। से Oracle के प्रलेखन :
ध्यान दें कि JVM केवल ढेर की तुलना में अधिक मेमोरी का उपयोग करता है। उदाहरण के लिए जावा विधि, थ्रेड स्टैक और देशी हैंडल को ढेर से अलग मेमोरी, साथ ही जेवीएम आंतरिक डेटा संरचनाओं में आवंटित किया जाता है।
OutOfMemoryError
घटना होगी।
-Xms256m
"256 MiB", "256 एमबी" नहीं, क्योंकि यह दस की शक्तियों के बजाय द्विआधारी शक्तियों द्वारा जाता है। En.wikipedia.org/wiki/Binary_prefix देखें । इसके अलावा, क्योंकि कुछ बेकार जगह सर्वाइवर स्पेस के अतिरिक्त पूल के लिए अलग रखी गई है, जो वास्तव में उपलब्ध है उसके अनुसार मेमोरी की मात्रा Runtime.getRuntime().maxMemory()
कमांड चलाएँ java -X
और आपको सभी -X
विकल्पों की एक सूची मिलेगी :
C:\Users\Admin>java -X
-Xmixed mixed mode execution (default)
-Xint interpreted mode execution only
-Xbootclasspath:<directories and zip/jar files separated by ;>
set search path for bootstrap classes and resources
-Xbootclasspath/a:<directories and zip/jar files separated by ;>
append to end of bootstrap class path
-Xbootclasspath/p:<directories and zip/jar files separated by ;>
prepend in front of bootstrap class path
-Xdiag show additional diagnostic messages
-Xnoclassgc disable class garbage collection
-Xincgc enable incremental garbage collection
-Xloggc:<file> log GC status to a file with time stamps
-Xbatch disable background compilation
-Xms<size> set initial Java heap size.........................
-Xmx<size> set maximum Java heap size.........................
-Xss<size> set java thread stack size
-Xprof output cpu profiling data
-Xfuture enable strictest checks, anticipating future default
-Xrs reduce use of OS signals by Java/VM (see documentation)
-Xcheck:jni perform additional checks for JNI functions
-Xshare:off do not attempt to use shared class data
-Xshare:auto use shared class data if possible (default)
-Xshare:on require using shared class data, otherwise fail.
-XshowSettings show all settings and continue
-XshowSettings:all show all settings and continue
-XshowSettings:vm show all vm related settings and continue
-XshowSettings:properties show all property settings and continue
-XshowSettings:locale show all locale related settings and continue
-X विकल्प गैर-मानक हैं और बिना सूचना के परिवर्तन के अधीन हैं।
मुझे उम्मीद है कि यह आपको समझने में मदद करेगा Xms
, Xmx
साथ ही कई अन्य चीजें जो सबसे ज्यादा मायने रखती हैं। :)
आप इसे अपनी आईडीई में निर्दिष्ट कर सकते हैं। उदाहरण के लिए, रन कॉन्फ़िगरेशन में ग्रहण के लिए → वीएम तर्क । आप के -Xmx800m -Xms500m
रूप में दर्ज कर सकते हैं
प्रश्न को पहले ही ऊपर संबोधित किया जा चुका है। बस डिफ़ॉल्ट मूल्यों का हिस्सा जोड़ना।
Http://docs.oracle.com/cd/E13150_01/jrockit_jvm/jrockit/jrdocs/refman/optionX.html के अनुसार
Xmx का डिफ़ॉल्ट मान प्लेटफ़ॉर्म और सिस्टम में उपलब्ध मेमोरी की मात्रा पर निर्भर करेगा।
-Xmx128m -Xms64m
इसका उपयोग275m
RES मेम के चारों ओर चोटी कर सकता है , लेकिन-Xmx128m -Xms128m
इसका उपयोग करते समय550m
RES मेम के चारों ओर चोटी कर सकते हैं Java 8 का उपयोग करते हुए सबसे अच्छी बात यह है कि GC पर जोर दें और जो होता है उसे देखें ...