इस पेज पर, Android रनटाइम (ART) को कॉन्फ़िगर करने और उसे कंपाइल करने के विकल्पों के बारे में बताया गया है. विषय
यहां इसके बारे में बताया गया है. इसमें सिस्टम इमेज के प्रीकंपाइलेशन का कॉन्फ़िगरेशन शामिल है, dex2oat
कंपाइलेशन के विकल्प उपलब्ध हैं. साथ ही, सिस्टम पार्टिशन स्पेस, डेटा पार्टिशन स्पेस, और
परफ़ॉर्मेंस.
ART के साथ काम करने के लिए ART और Delvik और Dalvik का एक्ज़ीक्यूटेबल फ़ॉर्मैट देखें. पुष्टि करने का तरीका देखें यह पक्का करने के लिए कि आपके ऐप्लिकेशन सही तरीके से काम करें, Android रनटाइम (ART) पर ऐप्लिकेशन व्यवहार सही तरीके से.
एआरटी कैसे काम करता है
ART, टाइम-ऑफ़-टाइम (एओटी) कंपाइलेशन का इस्तेमाल करता है. Android 7 की शुरुआत से, यह AOT कंपाइलेशन, जस्ट-इन-टाइम (JIT) कंपाइलेशन, और इंटरप्रेटेशन के हाइब्रिड कॉम्बिनेशन का इस्तेमाल करता है. और एओटी कंपाइलेशन का इस्तेमाल प्रोफ़ाइल में किया जा सकता है. ये सभी एक्ज़ीक्यूशन मोड एक साथ लागू होते हैं कॉन्फ़िगर किया जा सकता है और इस सेक्शन में इनके बारे में चर्चा की जाएगी. उदाहरण के लिए, Pixel डिवाइसों को काम नीचे दिया गया है:
- किसी ऐप्लिकेशन को शुरुआत में, dex मेटाडेटा (
.dm
) फ़ाइल के साथ इंस्टॉल किया जाता है Play Store, जिसमें क्लाउड प्रोफ़ाइल मौजूद हो. ART AOT, क्लाउड में बताए गए तरीकों को कंपाइल करता है प्रोफ़ाइल. अगर ऐप्लिकेशन को डेक्स मेटाडेटा फ़ाइल के बिना इंस्टॉल किया जाता है, तो एओटी को कंपाइल नहीं किया जाता प्रदर्शन किया. - जब शुरुआत में कुछ बार ऐप्लिकेशन चलाया जाता है, तो उन तरीकों को समझा जाता है जो एओटी से कंपाइल नहीं किए गए हैं. आम तौर पर, जिन मेथडों को एक्ज़ीक्यूट किया जाता है उनमें JIT को कंपाइल किया जाता है. एआरटी प्रोग्राम के तहत काम करने के हिसाब से, एक लोकल प्रोफ़ाइल जनरेट करता है और उसे क्लाउड प्रोफ़ाइल (अगर लागू हो) के साथ जोड़ता है मौजूद है).
- जब डिवाइस कुछ समय से इस्तेमाल में न हो और चार्ज हो रहा हो, तो ऐप्लिकेशन को फिर से कंपाइल करने के लिए, कंपाइलेशन डीमन चलता है यह डेटा, सर्वे की शुरुआत के कुछ समय के दौरान जनरेट हुई मिली-जुली प्रोफ़ाइल के आधार पर जनरेट किया गया है.
- ऐप्लिकेशन के बाद में चलाए जाने पर, ART कंपाइलेशन से जनरेट किए गए आर्टफ़ैक्ट का इस्तेमाल करता है डेमोन के दौरान, जनरेट हुए कोड की तुलना में, ज़्यादा एओटी से कंपाइल किया गया कोड होता है जिन तरीकों को एओटी से कंपाइल नहीं किया जाता उन्हें अब भी इंटरप्रेटेड या JIT से कंपाइल किया जाता है. ART प्रोफ़ाइल को अपडेट करता है और उसके बाद के चरण के आधार पर प्रोफ़ाइल को चुना जाएगा. कंपाइलेशन डीमन.
ART में एक कंपाइलर (dex2oat
टूल) और एक रनटाइम शामिल होता है
(libart.so
) है जो बूट के दौरान लोड होता है. कॉन्टेंट बनाने
dex2oat
टूल एक APK फ़ाइल लेता है और एक या एक से ज़्यादा APK फ़ाइल जनरेट करता है
कंपाइलेशन आर्टफ़ैक्ट फ़ाइलें, जिन्हें रनटाइम लोड करता है. फ़ाइलों की संख्या, उनकी
एक्सटेंशन और नाम रिलीज़ में बदल सकते हैं, लेकिन
Android 8 रिलीज़ होने पर, ये फ़ाइलें जनरेट होती हैं:
.vdex
: इसमें, पुष्टि की प्रक्रिया को तेज़ करने के लिए कुछ अतिरिक्त मेटाडेटा शामिल होता है. कभी-कभी ऐसा भी हो सकता है APK के बिना कंप्रेस किए DEX कोड के साथ..odex
: इसमें तरीकों के लिए एओटी से कंपाइल किया गया कोड शामिल होता है: APK के साथ काम करता है..art (optional)
में ART आंतरिक शामिल है APK में शामिल कुछ स्ट्रिंग और क्लास की जानकारी दिखाई जाती है. इसका इस्तेमाल तेज़ी से करने के लिए किया जाता है ऐप स्टार्टअप हो सकता है.
कंपाइलेशन के विकल्प
एआरटी के लिए कंपाइलेशन विकल्पों की दो कैटगरी हैं:
- सिस्टम ROM कॉन्फ़िगरेशन: फ़ाइल बनाते समय एओटी कौनसा कोड इकट्ठा करता है सिस्टम इमेज.
- रनटाइम कॉन्फ़िगरेशन: एआरटी, टाइम आउट के दौरान ऐप्लिकेशन को कैसे कंपाइल और रन करता है डिवाइस.
कंपाइलर फ़िल्टर
इन दो कैटगरी को कॉन्फ़िगर करने के लिए, ART का एक मुख्य विकल्प कंपाइलर है
फ़िल्टर. कंपाइलर फ़िल्टर से यह पता चलता है कि एआरटी, DEX कोड को कैसे कंपाइल करता है और
विकल्प dex2oat
टूल को पास किया गया. Android 8 और इसके बाद के वर्शन में,
आधिकारिक तौर पर काम करने वाले चार फ़िल्टर उपलब्ध हैं:
verify
: सिर्फ़ DEX कोड की पुष्टि करें (एओटी कंपाइलेशन नहीं है).quicken
: (Android 11 तक के लिए) DEX कोड चलाएं और बेहतर अनुवादक मोड के लिए कुछ DEX निर्देशों को ऑप्टिमाइज़ करें.speed
: DEX कोड की पुष्टि करें और सभी तरीकों को AOT-कंपाइल करें.speed-profile
: DEX कोड की पुष्टि और एओटी-कंपाइल तरीके चलाएं प्रोफ़ाइल फ़ाइल में मौजूद होता है.
सिस्टम ROM कॉन्फ़िगरेशन
पहले से इंस्टॉल की गई लाइब्रेरी और ऐप्लिकेशन, सिस्टम इमेज बनने के दौरान एओटी से कंपाइल किए जाते हैं. यह प्रक्रिया को dexpreopt कहते हैं. सभी डिपेंडेंसी होने पर ही, कंपाइल की गई ऐसी फ़ाइलों का इस्तेमाल किया जा सकता है कोई बदलाव नहीं किया जाएगा, खास तौर पर बूट क्लासपाथ.
ध्यान दें: अगर डिवाइस सिस्टम मॉड्यूल अपडेट करता है तो बूट क्लासपाथ बहुत के अगले अपडेट में बदल जाने की संभावना है, जिससे सभी dexpreopt फ़ाइलें पुरानी हो जाती हैं और उनका उपयोग नहीं किया जा सकता है.
dexpreopt को कॉन्फ़िगर करने के लिए कई ART बिल्ड विकल्प उपलब्ध हैं. कॉन्फ़िगर करने का तरीका ये विकल्प, सिस्टम इमेज के लिए उपलब्ध स्टोरेज स्पेस और पहले से इंस्टॉल किए गए ऐप्लिकेशन होते हैं. सिस्टम ROM में इकट्ठा किए जाने वाले JAR/APK को चार में बांटा जा सकता है श्रेणियां:
- बूट क्लासपाथ कोड:
speed-profile
कंपाइलर फ़िल्टर के साथ कंपाइल किया जाता है डिफ़ॉल्ट. - सिस्टम सर्वर कोड (
PRODUCT_SYSTEM_SERVER_JARS
देखें,PRODUCT_APEX_SYSTEM_SERVER_JARS
,PRODUCT_STANDALONE_SYSTEM_SERVER_JARS
, इस दस्तावेज़ मेंPRODUCT_APEX_STANDALONE_SYSTEM_SERVER_JARS
आगे दिया गया है):- (Android 14 और उसके बाद के वर्शन)
speed-profile
के साथ कंपाइल किए गए हैं डिफ़ॉल्ट रूप से कंपाइलर फ़िल्टर याspeed
कंपाइलर फ़िल्टर के साथ कंपाइल किया जाता है, अगर प्रोफ़ाइल उपलब्ध नहीं कराई गई है. - (Android 13 और उससे पहले वाले वर्शन के लिए)
speed
के साथ कंपाइल किया गया है डिफ़ॉल्ट रूप से कंपाइलर फ़िल्टर.
PRODUCT_SYSTEM_SERVER_COMPILER_FILTER
के ज़रिए कॉन्फ़िगर किया जा सकता है (इसे बाद में देखें दस्तावेज़). - (Android 14 और उसके बाद के वर्शन)
- प्रॉडक्ट के हिसाब से बने मुख्य ऐप्लिकेशन (इस लेख में
PRODUCT_DEXPREOPT_SPEED_APPS
को बाद में देखें दस्तावेज़: डिफ़ॉल्ट रूप से,speed
कंपाइलर फ़िल्टर के साथ कंपाइल किया जाता है. - अन्य सभी ऐप्लिकेशन: डिफ़ॉल्ट रूप से,
speed-profile
कंपाइलर फ़िल्टर के साथ कंपाइल किए जाते हैं, या प्रोफ़ाइल न मिलने पर,verify
कंपाइलर फ़िल्टर की मदद से कंपाइल किया जाता है.PRODUCT_DEX_PREOPT_DEFAULT_COMPILER_FILTER
के ज़रिए कॉन्फ़िगर किया जा सकता है (बाद में इसमें देखें दस्तावेज़).
मेकफ़ाइल के विकल्प
WITH_DEXPREOPT
DONT_DEXPREOPT_PREBUILTS
(Android 5 और उसके बाद वाले वर्शन के लिए)PRODUCT_DEX_PREOPT_DEFAULT_COMPILER_FILTER
(Android 9 वर्शन) और उच्च)WITH_DEXPREOPT_BOOT_IMG_AND_SYSTEM_SERVER_ONLY
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 8 MR1 के बाद से)LOCAL_DEX_PREOPT
PRODUCT_DEX_PREOPT_BOOT_FLAGS
PRODUCT_DEX_PREOPT_DEFAULT_FLAGS
PRODUCT_DEX_PREOPT_MODULE_CONFIGS
PRODUCT_DEXPREOPT_SPEED_APPS
(Android 8 के बाद से)PRODUCT_SYSTEM_SERVER_APPS
(Android 8 के बाद से)PRODUCT_ART_TARGET_INCLUDE_DEBUG_BUILD
(Android के बाद से 8)WITH_DEXPREOPT_PIC
(Android 7 तक)WITH_DEXPREOPT_BOOT_IMG_ONLY
(Android 7 तक MR1)PRODUCT_SYSTEM_SERVER_COMPILER_FILTER
- (Android 14 और उसके बाद के वर्शन) अगर साफ़ तौर पर नहीं बताया गया है, तो
speed-profile
कंपाइलर फ़िल्टर का इस्तेमाल किया जाता है. अगर प्रोफ़ाइल नहीं है, तोspeed
कंपाइलर फ़िल्टर का इस्तेमाल किया जाता है दिया गया है. - (Android 13 और उससे पहले वाले वर्शन के लिए) अगर जानकारी नहीं दी गई है, तो
speed
कंपाइलर फ़िल्टर का इस्तेमाल किया जाता है. - अगर इस नीति को
speed
पर सेट किया जाता है, तोspeed
कंपाइलर फ़िल्टर का इस्तेमाल किया जाता है. - अगर
speed-profile
पर सेट किया जाता है, तोspeed-profile
कंपाइलर फ़िल्टर का इस्तेमाल किया जाता है, या प्रोफ़ाइल न होने परverify
कंपाइलर फ़िल्टर का इस्तेमाल किया जाता है. - अगर इस नीति को
verify
पर सेट किया जाता है, तोverify
कंपाइलर फ़िल्टर का इस्तेमाल किया जाता है. PRODUCT_SYSTEM_SERVER_JARS
,PRODUCT_APEX_SYSTEM_SERVER_JARS
,PRODUCT_STANDALONE_SYSTEM_SERVER_JARS
,PRODUCT_APEX_STANDALONE_SYSTEM_SERVER_JARS
- (ज़रूरी है)
PRODUCT_SYSTEM_SERVER_JARS
: सिस्टम सर्वर क्लासपाथ JAR की सूची एक प्लैटफ़ॉर्म है (जोSYSTEMSERVERCLASSPATH
के हिस्से के तौर पर है). सिस्टम सर्वर जोड़ा जा रहा है इस सूची के लिए क्लासपाथ JAR ज़रूरी हैं. सूची में सिस्टम सर्वर क्लासपाथ JAR नहीं जोड़े जा सके इससे वे JAR लोड नहीं होंगे. - (ज़रूरी है)
PRODUCT_APEX_SYSTEM_SERVER_JARS
: सिस्टम सर्वर क्लासपाथ JAR की सूची APEX के साथ डिलीवर किया गया (यानी किSYSTEMSERVERCLASSPATH
के हिस्से के रूप में). फ़ॉर्मैट यह है<apex name>:<jar name>
. APEX सिस्टम सर्वर क्लासपाथ JAR जोड़ें यह सूची ज़रूरी है. इस सूची में APEX सिस्टम सर्वर क्लासपाथ JAR नहीं जोड़ने पर, ये नतीजे मिलेंगे वे JAR लोड नहीं हो रहे हैं. - (ज़रूरी नहीं है. Android 13 और उससे पहले के वर्शन के लिए)
PRODUCT_STANDALONE_SYSTEM_SERVER_JARS
: सिस्टम सर्वर लोड किए जाने वाले JAR की सूची अलग-अलग क्लासलोडर का इस्तेमाल करके (इसके ज़रिएSystemServiceManager.startServiceFromJar
). इसमें स्टैंडअलोन सिस्टम सर्वर JAR जोड़े जा रहे हैं यह सूची ज़रूरी नहीं है, लेकिन इसे ज़रूरी दिया गया है, क्योंकि यह JAR को कंपाइल करता है और इसलिए, रनटाइम का परफ़ॉर्मेंस अच्छा रहता है. - (Android 13 और इसके बाद के वर्शन में उपलब्ध है)
PRODUCT_APEX_STANDALONE_SYSTEM_SERVER_JARS
: इनकी सूची APEX के साथ डिलीवर किए गए JARs, जिन्हें सिस्टम सर्वर अलग-अलग क्लासलोडर का इस्तेमाल करके डाइनैमिक तौर पर लोड करता है (SystemServiceManager.startServiceFromJar
के माध्यम से या इस रूप में घोषित किया गया है<apex-system-service>
). फ़ॉर्मैट यह है<apex name>:<jar name>
. इसमें स्टैंडअलोन APEX सिस्टम सर्वर JARs जोड़े जा रहे हैं यह सूची ज़रूरी है. इस सूची में स्टैंडअलोन APEX सिस्टम सर्वर JAR नहीं जोड़ने पर, ये नतीजे मिलेंगे चालू नहीं हो सका.
सिस्टम इमेज पर इंस्टॉल किए गए DEX कोड पर, dex2oat
को शुरू किया जाता है या नहीं. यह सुविधा डिफ़ॉल्ट रूप से चालू होती है.
DONT_DEXPREOPT_PREBUILTS
को चालू करने से, पहले से बनाए गए एलिमेंट नहीं दिखेंगे
जिसमें सुधार किया गया है. इन ऐप्लिकेशन में include $(BUILD_PREBUILT)
है
उनके Android.mk
में मौजूद है. स्किप करना
पहले से बने ऐसे ऐप्लिकेशन जिन्हें Google Play से अपडेट किया जा सकता है
यह सिस्टम की इमेज में जगह बचाती है. हालांकि, डिवाइस के पहली बार चालू होने के समय में बढ़ोतरी होती है. ध्यान दें कि इस विकल्प से कोई असर नहीं पड़ता
Android.bp
में बताए गए, पहले से बने ऐप्लिकेशन के हिसाब से.
PRODUCT_DEX_PREOPT_DEFAULT_COMPILER_FILTER
, डिफ़ॉल्ट कंपाइलर फ़िल्टर के बारे में बताता है
dexpreopted ऐप्स के लिए. इन ऐप्लिकेशन के बारे में Android.bp
में बताया गया है या इनमें
include $(BUILD_PREBUILT)
की जानकारी अपने Android.mk
में दी गई है. अगर इसके बारे में जानकारी न दी गई हो,
डिफ़ॉल्ट मान speed-profile
है, या अगर मान न दिया गया हो, तो verify
है
और प्रोफ़ाइल उपलब्ध नहीं कराई गई है.
WITH_DEXPREOPT_BOOT_IMG_AND_SYSTEM_SERVER_ONLY
को सक्षम करने से केवल
बूट क्लासपाथ और सिस्टम सर्वर जार.
Dexpreopt को हर ऐप्लिकेशन के हिसाब से चालू या बंद किया जा सकता है. इसके लिए
मॉड्यूल की परिभाषा में, LOCAL_DEX_PREOPT
विकल्प को तय करके.
इसकी मदद से, उन ऐप्लिकेशन के लिए खोज बंद करने की सुविधा को बंद किया जा सकता है जिन्हें तुरंत ऐक्सेस किया जा सकता है
Google Play के अपडेट मिलेंगे, क्योंकि अपडेट करने पर
सिस्टम इमेज में मौजूद कोड पुराना हो गया है. यह मुख्य विषयों पर जगह बचाने में भी मदद करता है
को अपग्रेड करने का विकल्प होता है, क्योंकि हो सकता है कि उपयोगकर्ताओं के पास
डेटा विभाजन.
LOCAL_DEX_PREOPT
, true
या false
वैल्यू के साथ काम करता है, ताकि
dexpreopt को क्रम से चालू या बंद करना. इसके अलावा, nostripping
यह कर सकता है:
अगर dexpreopt को classes.dex
को स्ट्रिप करना नहीं चाहिए, तो बताया जाना चाहिए
फ़ाइल से लिया गया है. आम तौर पर इस फ़ाइल को हटा दिया जाता है क्योंकि यह कोई
dexpreopt के बाद ज़्यादा आवश्यक है, लेकिन यह अंतिम विकल्प
तीसरे पक्ष के APK हस्ताक्षरों को मान्य रहने दें.
इमेज के बूट की स्थिति को कंट्रोल करने के लिए, dex2oat
को विकल्प देता है
कंपाइल किया गया. इसका इस्तेमाल, पसंद के मुताबिक बनाई गई इमेज क्लास की सूचियों के बारे में बताने के लिए किया जा सकता है.
क्लास की सूची, और कंपाइलर फ़िल्टर का इस्तेमाल किया जा सकता है.
यह सेटिंग, dex2oat
को विकल्प देती है. इससे यह कंट्रोल किया जा सकता है कि
बूट इमेज को कंपाइल किया जाता है.
किसी खास क्वेरी के लिए, dex2oat
विकल्प पास करने की सुविधा मिलती है
मॉड्यूल और प्रॉडक्ट कॉन्फ़िगरेशन की ज़रूरत होती है. यह किसी प्रॉडक्ट के
$(call add-product-dex-preopt-module-config,<modules>,<option>)
की device.mk
फ़ाइल
जहां <modules>
, LOCAL_MODULE
और
JAR और APK फ़ाइलों के लिए, LOCAL_PACKAGE
नाम.
उन ऐप्लिकेशन की सूची जिनकी पहचान प्रॉडक्ट के मुख्य ऐप्लिकेशन के तौर पर की गई है और
जिन्हें speed
कंपाइलर फ़िल्टर के साथ कंपाइल किया जा सकता है. इसके लिए
उदाहरण के लिए, SystemUI जैसे स्थायी ऐप्लिकेशन को
केवल अगले रीबूट पर प्रोफ़ाइल-निर्देशित कंपाइलेशन, इसलिए यह
प्रॉडक्ट को हमेशा एओटी-कंपाइलेटेड बनाने के लिए किया जा सकता है.
सिस्टम सर्वर से लोड किए गए ऐप्लिकेशन की सूची. ये ऐप्लिकेशन
इन्हें speed
कंपाइलर फ़िल्टर के साथ डिफ़ॉल्ट रूप से कंपाइल किया जाता है.
क्या डिवाइस पर ART के डीबग वर्शन को शामिल करना है. डिफ़ॉल्ट रूप से, यह है
यह यूज़र डीबग और इंजीनियरिंग बिल्ड के लिए चालू है. व्यवहार को स्पष्ट रूप से बदला जा सकता है
true
या false
पर सेट करना है.
डिफ़ॉल्ट रूप से, यह डिवाइस, नॉन-डीबग वर्शन (libart.so
) का इस्तेमाल करता है.
स्विच करने के लिए, सिस्टम प्रॉपर्टी persist.sys.dalvik.vm.lib.2
को
libartd.so
.
Android 5.1.0 से Android 6.0.1 तक, WITH_DEXPREOPT_PIC
ये काम कर सकता है:
स्थिति-स्वतंत्र कोड (PIC) को सक्षम करने के लिए बताया जाना चाहिए. इसके साथ, कंपाइल किए गए
इमेज में मौजूद कोड को दूसरी जगह ले जाने की ज़रूरत नहीं है
/system
, /data/dalvik-cache
में. इससे डेटा पार्टिशन में जगह खाली हो रही है.
हालांकि, रनटाइम का थोड़ा असर होता है, क्योंकि इससे ऑप्टिमाइज़ेशन की सुविधा बंद हो जाती है.
की जगह पर निर्भर करता है. आम तौर पर, वे डिवाइस जो /data
में जगह बचाना चाहते हैं
को पीआईसी कंपाइलेशन चालू करना चाहिए.
Android 7.0 में, PIC कंपाइलेशन डिफ़ॉल्ट रूप से चालू था.
इस विकल्प को WITH_DEXPREOPT_BOOT_IMG_AND_SYSTEM_SERVER_ONLY
से बदल दिया गया था
जो सिस्टम सर्वर के JAR को भी शामिल करती है.
यह विकल्प, सिस्टम सर्वर के लिए कंपाइलर फ़िल्टर के बारे में बताता है.
सिस्टम सर्वर से लोड किए जाने वाले JAR की सूचियां नीचे दी गई हैं. JAR को
PRODUCT_SYSTEM_SERVER_COMPILER_FILTER
से तय किया गया कंपाइलर फ़िल्टर
बूट क्लासपाथ कॉन्फ़िगरेशन
पहले से लोड की गई क्लास की सूची, उन क्लास की सूची है जिन्हें Zygote शुरू करता है
शुरू करें. इससे हर ऐप्लिकेशन को क्लास शुरू करने वाले ये टूल चलाने की ज़रूरत नहीं पड़ती
इससे उन्हें तेज़ी से शुरू करने और मेमोरी में पेजों को शेयर करने में मदद मिलती है. कॉन्टेंट बनाने
पहले से लोड की गई क्लास की सूची वाली फ़ाइल, frameworks/base/config/preloaded-classes
पर मौजूद है
डिफ़ॉल्ट रूप से होता है, और इसमें एक ऐसी सूची होती है जो सामान्य फ़ोन उपयोग के लिए ट्यून की जाती है. यह हो सकता है
अन्य डिवाइसों के लिए अलग हो, जैसे कि पहने जाने वाले डिवाइस. साथ ही, इसे ट्यून किया जाना चाहिए
उसी के हिसाब से. इसे ट्यून करते समय सावधान रहें; कई क्लास कचरे को रीसाइकल करना
इस्तेमाल न की गई क्लास लोड होने पर मेमोरी. बहुत कम क्लास जोड़ने से हर ऐप्लिकेशन को
उसकी अपनी कॉपी नहीं होती है, जिससे फिर से मेमोरी बर्बाद हो जाती है.
इस्तेमाल के उदाहरण (प्रॉडक्ट के device.mk
में):
PRODUCT_COPY_FILES += <filename>:system/etc/preloaded-classes
ध्यान दें: आपको पहले यह लाइन रखनी होगी
किसी भी प्रॉडक्ट कॉन्फ़िगरेशन को इनहेरिट करने से, ऐसी फ़ाइलें बन जाती हैं जिन्हें डिफ़ॉल्ट तौर पर
build/target/product/base.mk
.
रनटाइम कॉन्फ़िगरेशन
JIT के विकल्प
ये विकल्प, Android की उन रिलीज़ पर असर डालते हैं जिनमें ART JIT कंपाइलर काम करता है उपलब्ध है.
dalvik.vm.usejit
: JIT चालू है या नहीं.dalvik.vm.jitinitialsize
(डिफ़ॉल्ट 64K): शुरुआती कपैसिटी कोड कैश मेमोरी में सेव किया जा सकता है. कोड कैश मेमोरी को समय-समय पर इस्तेमाल किया जाएगा. साथ ही, ज़रूरत पड़ने पर इसे बढ़ाया जाएगा.dalvik.vm.jitmaxsize
(डिफ़ॉल्ट 64M): कोड की कैश मेमोरी की ज़्यादा से ज़्यादा क्षमता.dalvik.vm.jitthreshold
(डिफ़ॉल्ट 10000): वह थ्रेशोल्ड जिस पर "हॉटनेस" काउंटर ऑफ़ हो जाने पर, JIT-कंपाइलेशन के लिए इस्तेमाल किया जाता है. "हॉटनेस" काउंटर एक आंतरिक मेट्रिक है के लिए इस्तेमाल किया जा सकता है. इसमें कॉल, बैकवर्ड ब्रांच की संख्या, और अन्य फ़ैक्टर.dalvik.vm.usejitprofiles
(Android 13 तक के लिए): क्या JIT की प्रोफ़ाइलें चालू नहीं हैं; इसका इस्तेमाल तब भी किया जा सकता है, जबdalvik.vm.usejit
गलत हो. ध्यान दें कि अगर यह वैल्यू गलत है, तो कंपाइलर फ़िल्टरspeed-profile
किसी भी तरीके को एओटी-कंपाइल नहीं करता और यहverify
के बराबर है. से Android 14 और JIT प्रोफ़ाइलें हमेशा चालू रहती हैं और इन्हें बंद नहीं किया जा सकता.dalvik.vm.jitprithreadweight
(डिफ़ॉल्ट रूप से यह होता हैdalvik.vm.jitthreshold
/ 20): JIT "सैंपल" का वज़न ऐप्लिकेशन यूज़र इंटरफ़ेस (यूआई) थ्रेड के लिए (jitthreshold देखें). कंपाइलेशन की स्पीड बढ़ाने के लिए इसका इस्तेमाल करें के साथ इंटरैक्ट करते समय उपयोगकर्ता अनुभव को सीधे तौर पर प्रभावित करते हैं. है.dalvik.vm.jittransitionweight
(डिफ़ॉल्ट रूप से यह होता हैdalvik.vm.jitthreshold
/ 10): तरीके का महत्व यह कंपाइल कोड और इंटरप्रेटर के बीच ट्रांज़िशन करता है. इससे मदद मिली पक्का कर लें कि इसमें शामिल तरीकों को कंपाइल किया गया है, ताकि ट्रांज़िशन को कम किया जा सके (जो महंगा).
डेक्स2ओट के विकल्प
ये विकल्प, उपयोगकर्ता के डिवाइस पर मौजूद डेटा को कंपाइल करने की प्रोसेस पर असर डालते हैं. जैसे, dexopt. साथ ही, कुछ विकल्पों से dexpreopt में शामिल किया गया है, जबकि सिर्फ़ ऊपर दिए गए सिस्टम ROM कॉन्फ़िगरेशन सेक्शन में बताए गए विकल्प dexpreopt को प्रभावित करता है.
संसाधन के इस्तेमाल को कंट्रोल करने के विकल्प:
dalvik.vm.image-dex2oat-threads
/dalvik.vm.image-dex2oat-cpu-set
(Android 11 तक के लिए): थ्रेड की संख्या और सीपीयू कोर का सेट (देखें (नीचे) बूट इमेज के लिए इस्तेमाल किया जाएगा.dalvik.vm.boot-dex2oat-threads
/dalvik.vm.boot-dex2oat-cpu-set
:- (Android 11 तक के वर्शन) थ्रेड की संख्या और सीपीयू कोर का सेट (नीचे देखें) बूट चित्र के अलावा अन्य सभी चीज़ों के लिए बूट समय के दौरान उपयोग करने के लिए.
- (Android 12 के बाद से) थ्रेड की संख्या और सीपीयू कोर का सेट
(नीचे देखें) बूट चित्र सहित हर चीज़ के लिए बूट समय के दौरान उपयोग करने के लिए.
- खास तौर पर, Android 14 के बाद से, यह
ART सेवा में प्राथमिकता श्रेणी
PRIORITY_BOOT
.
- खास तौर पर, Android 14 के बाद से, यह
ART सेवा में प्राथमिकता श्रेणी
dalvik.vm.restore-dex2oat-threads
/dalvik.vm.restore-dex2oat-cpu-set
:- (Android 11 और Android 13 के बाद के वर्शन पर) क्लाउड से डेटा वापस पाने के लिए थ्रेड की संख्या और सीपीयू कोर का सेट (नीचे देखें) बैकअप लें.
- (Android 14 के बाद से) थ्रेड की संख्या और सीपीयू कोर का सेट
(नीचे देखें) ऐसी सभी चीज़ों के लिए इस्तेमाल किया जाएगा जो सामान्य से ज़्यादा इंतज़ार के समय के लिए संवेदनशील हैं. इसमें ये शामिल हैं
क्लाउड बैकअप से पुनर्स्थापित करना.
- खास तौर पर, यह प्रायॉरिटी क्लास के बारे में है
एआरटी सेवा में
PRIORITY_INTERACTIVE_FAST
.
- खास तौर पर, यह प्रायॉरिटी क्लास के बारे में है
एआरटी सेवा में
dalvik.vm.background-dex2oat-threads
/dalvik.vm.background-dex2oat-cpu-set
(Android 14 के बाद से): थ्रेड की संख्या और सीपीयू कोर का सेट (देखें का इस्तेमाल करें).- खास तौर पर, यह इस इवेंट की प्राथमिकता क्लास
PRIORITY_BACKGROUND
से मेल खाता है एआरटी सेवा.
- खास तौर पर, यह इस इवेंट की प्राथमिकता क्लास
dalvik.vm.dex2oat-threads
/dalvik.vm.dex2oat-cpu-set
: बाकी सभी चीज़ों के लिए इस्तेमाल किए जाने वाले थ्रेड की संख्या और सीपीयू कोर का सेट.
सीपीयू कोर के सेट को, कॉमा लगाकर अलग किए गए सीपीयू आईडी की सूची के तौर पर बताया जाना चाहिए. उदाहरण के लिए: CPU कोर 0-3 पर dex2oat के लिए, सेट करें:
dalvik.vm.dex2oat-cpu-set=0,1,2,3
हमारा सुझाव है कि सीपीयू अफ़िनिटी प्रॉपर्टी को सेट करते समय, ग़ैर-ज़रूरी मेमोरी और I/O से बचने के लिए, चुने गए सीपीयू की संख्या से मैच करने के लिए dex2oat थ्रेड की संख्या विवाद:
dalvik.vm.dex2oat-cpu-set=0,1,2,3 dalvik.vm.dex2oat-threads=4
ऊपर दी गई सिस्टम प्रॉपर्टी के अलावा, टास्क प्रोफ़ाइल का इस्तेमाल करके, dex2oat के संसाधन का इस्तेमाल (Cgroup ऐब्स्ट्रैक्शन लेयर देखें).
इन टास्क प्रोफ़ाइलों का इस्तेमाल किया जा सकता है:
Dex2OatBackground
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 14 के बाद के वर्शन) (डिफ़ॉल्ट रूप से,Dex2OatBootComplete
को इनहेरिट करता है): यह नीति बैकग्राउंड में इस्तेमाल करने के लिए, संसाधनों को कंट्रोल करती है.- खास तौर पर, यह इस इवेंट की प्राथमिकता क्लास
PRIORITY_BACKGROUND
से मेल खाता है एआरटी सेवा.
- खास तौर पर, यह इस इवेंट की प्राथमिकता क्लास
Dex2OatBootComplete
:- (Android 13 तक के लिए) संसाधन को कंट्रोल करता है, ताकि हर काम के लिए उसका इस्तेमाल किया जा सके बूट के बाद.
- (Android 14 के बाद के वर्शन) सभी कामों के लिए इस्तेमाल किए जाने वाले संसाधन को कंट्रोल करता है
बैकग्राउंड में नहीं, बल्कि चालू होने के बाद भी.
- खास तौर पर, यह प्रायॉरिटी क्लास के बारे में है
एआरटी में
PRIORITY_INTERACTIVE_FAST
औरPRIORITY_INTERACTIVE
सेवा.
- खास तौर पर, यह प्रायॉरिटी क्लास के बारे में है
एआरटी में
जब सिस्टम प्रॉपर्टी और टास्क प्रोफ़ाइल, दोनों तय किए जाते हैं, तो दोनों काम करते हैं.
हीप के साइज़ को कंट्रोल करने के विकल्प:
dalvik.vm.image-dex2oat-Xms
: बूट इमेज के लिए शुरुआती हीप साइज़.dalvik.vm.image-dex2oat-Xmx
: बूट इमेज के लिए ज़्यादा से ज़्यादा हीप साइज़.dalvik.vm.dex2oat-Xms
: बाकी सभी चीज़ों के लिए शुरुआती हीप साइज़.dalvik.vm.dex2oat-Xmx
: बाकी सभी चीज़ों के लिए ज़्यादा से ज़्यादा हीप साइज़.
वे विकल्प जो इसके लिए शुरुआती और ज़्यादा से ज़्यादा हीप साइज़ को कंट्रोल करते हैं
dex2oat
को कम नहीं करना चाहिए, क्योंकि इससे क्या
ऐप्लिकेशन को कंपाइल किया जा सकता है.
कंपाइलर फ़िल्टर को कंट्रोल करने के विकल्प:
dalvik.vm.image-dex2oat-filter
(Android 11 तक के लिए): बूट इमेज के लिए कंपाइलर फ़िल्टर. Android 12 के बाद से, कंपाइलर बूट इमेज का फ़िल्टर हमेशाspeed-profile
होता है और इसे बदला नहीं जा सकता.dalvik.vm.systemservercompilerfilter
(Android 13 के बाद के वर्शन): सिस्टम सर्वर के लिए कंपाइलर फ़िल्टर. देखेंPRODUCT_SYSTEM_SERVER_COMPILER_FILTER
.dalvik.vm.systemuicompilerfilter
(Android 13 के बाद के वर्शन): सिस्टम यूज़र इंटरफ़ेस (यूआई) पैकेज के लिए कंपाइलर फ़िल्टर.dalvik.vm.dex2oat-filter
(Android 6 तक): बाकी सभी चीज़ों के लिए कंपाइलर फ़िल्टर.pm.dexopt.<reason>
(Android 7 के बाद वाले वर्शन के लिए): बाकी सभी चीज़ों के लिए कंपाइलर फ़िल्टर. यहां जाएं: Android के लिए ART सेवा कॉन्फ़िगरेशन 14 साल और उससे ज़्यादा उम्र के बच्चों के लिए या के लिए पैकेज मैनेजर कॉन्फ़िगरेशन Android 13 और इससे पहले के वर्शन के लिए.
बूट इमेज के अलावा सभी चीज़ों के कंपाइलेशन को कंट्रोल करने के अन्य विकल्प:
dalvik.vm.dex2oat-very-large
(Android 7.1 के बाद वाले वर्शन के लिए): डेक्स फ़ाइल का कम से कम कुल साइज़ बाइट डालें.dalvik.vm.dex2oat-swap
(Android 7.1 के बाद वाले वर्शन के साथ) (डिफ़ॉल्ट: सही): स्वैप करने की अनुमति देता है dex2oat के लिए फ़ाइल डाउनलोड करें. इससे, स्टोरेज खत्म होने की वजह से होने वाले क्रैश से बचा जा सकता है. ध्यान दें कि भले ही यह विकल्प यह सुविधा चालू होने पर, dex2oat सिर्फ़ कुछ स्थितियों में स्वैप फ़ाइल का इस्तेमाल करेगा. उदाहरण के लिए, dex फ़ाइलें बड़ी होती हैं और इनकी शर्तों में बदलाव हो सकता है.dalvik.vm.ps-min-first-save-ms
(Android 12 के बाद के वर्शन के लिए): रनटाइम के ज़रिए ऐप्लिकेशन की प्रोफ़ाइल जनरेट करने से पहले, इंतज़ार करने में लगने वाला कम से कम समय ऐप्लिकेशन लॉन्च हो जाता है.dalvik.vm.ps-min-save-period-ms
(Android 12 के बाद के वर्शन के लिए): ऐप्लिकेशन की प्रोफ़ाइल अपडेट करने में कम से कम समय लगेगा.dalvik.vm.dex2oat64.enabled
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 11 के बाद के वर्शन) (डिफ़ॉल्ट: false): dex2oat का 64-बिट वर्शन इस्तेमाल करना है या नहीं.dalvik.vm.bgdexopt.new-classes-percent
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 12 के बाद के वर्शन) (डिफ़ॉल्ट: 20): फिर से कंपाइलेशन ट्रिगर करने के लिए, किसी प्रोफ़ाइल में नई क्लास का कम से कम प्रतिशत. यह संख्या 0 से 100 के बीच होती है. सिर्फ़ प्रोफ़ाइल के हिसाब से डेटा को इकट्ठा करने की सुविधा (speed-profile
) पर लागू होता है, जो आम तौर पर बैकग्राउंड डीक्ज़ॉप्ट. ध्यान दें कि क्लास के अतिरिक्त कम से कम 50 नए क्लास का थ्रेशोल्ड भी मौजूद है प्रतिशत की सीमा होती है और इसे कॉन्फ़िगर नहीं किया जा सकता.dalvik.vm.bgdexopt.new-methods-percent
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 12 के बाद के वर्शन) (डिफ़ॉल्ट: 20): फिर से कंपाइलेशन ट्रिगर करने के लिए प्रोफ़ाइल में नई तरीकों का कम से कम प्रतिशत, जो 0 से 100 के बीच होता है. सिर्फ़ प्रोफ़ाइल के हिसाब से डेटा को इकट्ठा करने की सुविधा (speed-profile
) पर लागू होता है, जो आम तौर पर बैकग्राउंड डीक्ज़ॉप्ट. ध्यान दें कि इसके अलावा कम से कम 100 नए तरीकों के थ्रेशोल्ड भी मौजूद हैं है और इसे कॉन्फ़िगर नहीं किया जा सकता.dalvik.vm.dex2oat-max-image-block-size
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 10 के बाद के वर्शन) (डिफ़ॉल्ट: 524288) कंप्रेस की गई इमेज के लिए ब्लॉक का ज़्यादा से ज़्यादा साइज़. बड़ी इमेज को सॉलिड के सेट में बांटा गया है इस तरह ब्लॉक कर दें कि कोई भी ब्लॉक अधिकतम आकार से बड़ा न हो.dalvik.vm.dex2oat-resolve-startup-strings
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 10 के बाद के वर्शन) (डिफ़ॉल्ट: सही) अगर सही है, तो dex2oat से उन सभी कॉन्स्ट-स्ट्रिंग को ठीक किया जाता है जिन्हें इस तौर पर मार्क किए गए तरीकों से रेफ़र किया गया है "स्टार्टअप" प्रोफ़ाइल में.debug.generate-debug-info
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (डिफ़ॉल्ट: गलत) नेटिव डीबगिंग के लिए डीबग की जानकारी जनरेट करनी है या नहीं, जैसे कि स्टैक अनंडिंग जानकारी, ईएलएफ़ सिंबल, और बौनों के सेक्शन.dalvik.vm.dex2oat-minidebuginfo
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है (Android 9 के बाद से) (डिफ़ॉल्ट: सही) इस बात के लिए ज़रूरी है कि LZMA की कंप्रेस की गई डीबग जानकारी कम से कम जनरेट की जाए या नहीं इसे प्रिंट करता है.
एआरटी सेवा के विकल्प
Android 14 और इसके बाद के वर्शन में, डिवाइस पर मौजूद एओटी को अलग-अलग ऐप्लिकेशन के लिए कंपाइल किया जा रहा है. जैसे, dexopt ART Service द्वारा प्रबंधित किया जाता है. ART सेवा को कॉन्फ़िगर करने के बारे में जानकारी के लिए देखें आर्ट सर्विस का कॉन्फ़िगरेशन.पैकेज मैनेजर के विकल्प
Android 14 से पहले के वर्शन में, डिवाइस पर मौजूद ऐप्लिकेशन के लिए एओटी को कंपाइलेशन (यानी कि dexopt) होता है इसे पैकेज मैनेजर मैनेज करता है. dexopt के लिए पैकेज मैनेजर को कॉन्फ़िगर करने के बारे में जानकारी के लिए, पैकेज मैनेजर कॉन्फ़िगरेशन देखें.A/B के लिए खास कॉन्फ़िगरेशन
ROM कॉन्फ़िगरेशन
Android 7.0 से, डिवाइस चालू करने के लिए दो सिस्टम पार्टीशन का इस्तेमाल कर सकते हैं A/B सिस्टम अपडेट. सिस्टम पार्टिशन का साइज़ सेव करने के लिए, पहले से इस्तेमाल की गई फ़ाइलों को यहां इंस्टॉल किया जा सकता है दूसरे सिस्टम का दूसरा हिस्सा इस्तेमाल नहीं किया जा सकता. इसके बाद, उन्हें डेटा पार्टिशन में कॉपी किया जाता है पहले बूट पर.
इस्तेमाल के उदाहरण (device-common.mk
में):
PRODUCT_PACKAGES += \ cppreopts.sh PRODUCT_PROPERTY_OVERRIDES += \ ro.cp_system_other_odex=1
डिवाइस के BoardConfig.mk
में:
BOARD_USES_SYSTEM_OTHER_ODEX := true
ध्यान दें कि बूट क्लासपाथ कोड, सिस्टम सर्वर कोड, और प्रॉडक्ट खास कोर
ऐप्लिकेशन हमेशा सिस्टम पार्टिशन में इकट्ठा होते हैं. डिफ़ॉल्ट रूप से, अन्य सभी
ऐप्लिकेशन को इस्तेमाल न किए गए दूसरे सिस्टम पार्टीशन में कंपाइल किया जाता है. यह काम किया जा सकता है
SYSTEM_OTHER_ODEX_FILTER
से कंट्रोल किया जाता है, जिसकी वैल्यू
इसका डिफ़ॉल्ट:
SYSTEM_OTHER_ODEX_FILTER ?= app/% priv-app/%
बैकग्राउंड में लागू होने वाले ओटीए डेक्सऑप्ट
A/B सक्षम डिवाइस पर, रीबूट से पहले ऐप्लिकेशन को नया सिस्टम इमेज. ऐप्लिकेशन कंपाइलेशन इसमें देखें बैकग्राउंड का भी इस्तेमाल किया जा सकता है. कॉन्टेंट बनाने इस कंपाइलेशन के लिए इस्तेमाल किया गया फ़िल्टर, इससे कंट्रोल किया जाता है:
pm.dexopt.ab-ota=speed-profile
अगर आपको प्रोफ़ाइल गाइड का इस्तेमाल करना है, तो हमारा सुझाव है कि आप speed-profile
का इस्तेमाल करें
और स्टोरेज पर बचत करने के लिए किया जा सकता है.
JDWP के विकल्प
यूज़र डीबग बिल्ड में Java डीबग वायर प्रोटोकॉल (JDWP) थ्रेड बनाने को इसके ज़रिए कंट्रोल किया जाता है
persist.debug.dalvik.vm.jdwp.enabled
सिस्टम प्रॉपर्टी. डिफ़ॉल्ट रूप से, यह प्रॉपर्टी
सेट नहीं है और JDWP थ्रेड सिर्फ़ डीबग किए जा सकने वाले ऐप्लिकेशन के लिए बनाए जाते हैं. दोनों के लिए JDWP थ्रेड चालू करने के लिए
डीबग करने लायक और डीबग नहीं किए जा सकने वाले ऐप्लिकेशन, persist.debug.dalvik.vm.jdwp.enabled
सेट करें
1
तक. प्रॉपर्टी में किए गए बदलावों को लागू करने के लिए, डिवाइस को फिर से चालू करना होगा.
यूज़रडीबग बिल्ड पर डीबग करने लायक ऐप्लिकेशन को डीबग करने के लिए, नीचे दिए गए निर्देश अपनाकर JDWP को चालू करें आदेश:
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है Android 13 और उससे पहले के वर्शन वाले डिवाइसों के लिए, रनटाइम JDWP बनाता है userdebug बिल्ड पर डीबग करने लायक और न डीबग करने लायक ऐप्लिकेशन के लिए थ्रेड. इसका मतलब है कि यह मुमकिन है कि का इस्तेमाल, डीबगर को अटैच करने या userडीबग बिल्ड पर किसी ऐप्लिकेशन की प्रोफ़ाइल करने के लिए किया होगा.adb shell setprop persist.debug.dalvik.vm.jdwp.enabled 1
adb reboot