Jack, Android 6.0 से 8.1 के लिए डिफ़ॉल्ट Android बिल्ड टूलचेन है
Jack, Android टूलचेन है. यह Java सोर्स को Android dex बाइटकोड में कंपाइल करता है. Jack का इस्तेमाल करने के लिए, आपको कुछ भी अलग से करने की ज़रूरत नहीं है. ट्री या अपने प्रोजेक्ट को कंपाइल करने के लिए, बस अपने स्टैंडर्ड मेकफ़ाइल कमांड का इस्तेमाल करें. Android 8.1, Jack का इस्तेमाल करने वाला आखिरी वर्शन है.
जैक के बारे में जानकारी
Jack, पहली इमेज में दिखाए गए तरीके से काम करता है.
 
 
पहली इमेज. जैक की खास जानकारी.
Jack लाइब्रेरी का फ़ॉर्मैट
Jack का अपना .jack फ़ाइल फ़ॉर्मैट होता है. इसमें लाइब्रेरी के लिए पहले से कंपाइल किया गया dex कोड होता है. इससे कंपाइल करने की प्रोसेस (प्री-डेक्स) तेज़ी से होती है.
 
 
दूसरी इमेज. Jack की लाइब्रेरी फ़ाइल का कॉन्टेंट.
जिल
नीचे दिए गए डायग्राम में दिखाया गया है कि Jill टूल, मौजूदा .jar लाइब्रेरी को नए लाइब्रेरी फ़ॉर्मैट में बदलता है.
 
 
तीसरी इमेज. मौजूदा .jar लाइब्रेरी को इंपोर्ट करने का तरीका.
Jack कंपाइलेशन सर्वर
Jack का पहली बार इस्तेमाल करने पर, यह आपके कंप्यूटर पर एक लोकल Jack कंपाइलेशन सर्वर लॉन्च करता है. यह सर्वर:
- इससे कंपाइल करने की प्रोसेस तेज़ हो जाती है, क्योंकि यह हर कंपाइलेशन में, नए होस्ट JRE JVM को लॉन्च करने, जैक कोड को लोड करने, जैक को शुरू करने, और JIT को वार्म अप करने से बचता है. यह छोटे कंपाइलेशन के दौरान, कंपाइल होने में लगने वाला समय भी कम करता है. उदाहरण के लिए, इंक्रीमेंटल मोड में.
- यह एक ऐसा विकल्प है जिससे कुछ समय के लिए, एक साथ कई Jack फ़ाइलों को कंपाइल करने की सुविधा को कंट्रोल किया जा सकता है. सर्वर, आपके कंप्यूटर पर ज़्यादा लोड नहीं डालता. ऐसा इसलिए होता है, क्योंकि यह एक साथ कई कंपाइलेशन को सीमित करता है.
Jack सर्वर, कुछ समय तक कोई गतिविधि न होने पर अपने-आप बंद हो जाता है.
यह लोकलहोस्ट इंटरफ़ेस पर दो टीसीपी पोर्ट का इस्तेमाल करता है और बाहरी तौर पर उपलब्ध नहीं है. $HOME/.jack फ़ाइल में बदलाव करके, सभी पैरामीटर (पैरलल कंपाइलेशन की संख्या, टाइम आउट, पोर्ट नंबर वगैरह) में बदलाव किया जा सकता है.
$HOME/.jack फ़ाइल
$HOME/.jack फ़ाइल में, पूरे बैश सिंटैक्स में Jack
server वैरिएबल के लिए ये सेटिंग शामिल हैं:
- SERVER=true, Jack की सर्वर सुविधा को चालू करता है.
- SERVER_PORT_SERVICE=8072कंपाइल करने के लिए, सर्वर का टीसीपी पोर्ट नंबर सेट करता है.
- SERVER_PORT_ADMIN=8073एडमिन के लिए, सर्वर का टीसीपी पोर्ट नंबर सेट करता है.
- SERVER_COUNT=1का इस्तेमाल नहीं किया गया है.
- SERVER_NB_COMPILE=4से, एक साथ कंपाइल किए जा सकने वाले फ़ाइलों की ज़्यादा से ज़्यादा संख्या सेट की जाती है.- SERVER_TIMEOUT=60से, सर्वर के बंद होने से पहले, कंपाइल किए बिना इंतज़ार करने के लिए सेकंड की संख्या सेट की जाती है.- SERVER_LOG=${SERVER_LOG:=$SERVER_DIR/jack-$SERVER_PORT_SERVICE.log}इस विकल्प का इस्तेमाल करके, वह फ़ाइल सेट की जाती है जिसमें सर्वर लॉग लिखे जाते हैं. डिफ़ॉल्ट रूप से, इस वैरिएबल को एनवायरमेंट वैरिएबल से ओवरलोड किया जा सकता है.
- JACK_VM_COMMAND=${JACK_VM_COMMAND:=java}, होस्ट पर JVM लॉन्च करने के लिए इस्तेमाल किए जाने वाले डिफ़ॉल्ट कमांड को सेट करता है. डिफ़ॉल्ट रूप से, इस वैरिएबल को एनवायरमेंट वैरिएबल से ओवरलोड किया जा सकता है.
Jack कंपाइलेशन से जुड़ी समस्याएं हल करना
| समस्या | कार्रवाई | 
|---|---|
| कंपाइल करने के दौरान आपका कंप्यूटर काम नहीं करता या आपको मेमोरी से जुड़ी गड़बड़ी के कारण, जैक कंपाइलेशन में समस्या आ रही है | $HOME/.jackमें बदलाव करके औरSERVER_NB_COMPILEको कम वैल्यू पर सेट करके, एक साथ होने वाले Jack कंपाइलेशन की संख्या कम करें. | 
| बैकग्राउंड सर्वर लॉन्च नहीं किया जा सका की वजह से, कंपाइल नहीं हो पा रहा है | इस समस्या की मुख्य वजह यह है कि आपके कंप्यूटर पर टीसीपी पोर्ट पहले से ही इस्तेमाल किए जा रहे हैं. $HOME/.jack(SERVER_PORT_SERVICEऔरSERVER_PORT_ADMINवैरिएबल) में बदलाव करके पोर्ट बदलें. इस समस्या को ठीक करने के लिए, Jack कंपाइलेशन सर्वर को बंद करें. इसके लिए,$HOME/.jackमें बदलाव करें औरSERVERकोfalseपर सेट करें. माफ़ करें, इससे कंपाइल करने की प्रोसेस काफ़ी धीमी हो जाती है. साथ ही, आपको लोड कंट्रोल (makeका विकल्प-l) के साथmake -jलॉन्च करना पड़ सकता है. | 
| कंपाइलेशन की प्रोसेस आगे नहीं बढ़ रही है | इस समस्या को ठीक करने के लिए, jack-admin kill-serverका इस्तेमाल करके Jack के बैकग्राउंड सर्वर को बंद करें. इसके बाद, अपनी अस्थायी डायरेक्ट्री (/tmpया$TMPDIR) कीjack-$USERमें मौजूद अस्थायी डायरेक्ट्री हटाएं. | 
जैक लॉग ढूंढना
अगर आपने डिस्ट्रिब्यूशन टारगेट के साथ make कमांड चलाई है, तो जैक लॉग $ANDROID_BUILD_TOP/out/dist/logs/jack-server.log पर मौजूद होता है.
इसके अलावा, jack-admin server-log चलाकर भी लॉग का पता लगाया जा सकता है.
अगर जैक की गड़बड़ियों को फिर से ठीक किया जा सकता है, तो यहां दिए गए वैरिएबल को सेट करके ज़्यादा जानकारी वाला लॉग पाया जा सकता है:
export ANDROID_JACK_EXTRA_ARGS="--verbose debug --sanity-checks on -D sched.runner=single-threaded"
ट्री (या अपने प्रोजेक्ट) को कंपाइल करने के लिए, स्टैंडर्ड मेकफ़ाइल कमांड का इस्तेमाल करें. साथ ही, स्टैंडर्ड आउटपुट और गड़बड़ी को अटैच करें. ज़्यादा जानकारी वाले बिल्ड लॉग हटाने के लिए, यह कमांड चलाएं:
unset ANDROID_JACK_EXTRA_ARGS
जैक की सीमाएं
डिफ़ॉल्ट रूप से, जैक सर्वर का इस्तेमाल किसी कंप्यूटर पर सिर्फ़ एक उपयोगकर्ता कर सकता है. ज़्यादा उपयोगकर्ताओं के लिए, हर उपयोगकर्ता के लिए अलग-अलग पोर्ट नंबर चुनें और SERVER_NB_COMPILE को उसके हिसाब से अडजस्ट करें. $HOME/.jack में SERVER=false को सेट करके, जैक सर्वर को भी बंद किया जा सकता है.
मौजूदा vm-tests-tf इंटिग्रेशन की वजह से, CTS कंपाइलेशन की प्रोसेस धीमी है.
बाइटकोड में बदलाव करने वाले टूल (जैसे कि JaCoCo) काम नहीं करते.
Jack का इस्तेमाल करना
Jack, Java प्रोग्रामिंग लैंग्वेज 1.7 के साथ काम करता है. साथ ही, इसमें यहां दी गई अतिरिक्त सुविधाएं शामिल हैं.
प्री-डेक्स
Jack लाइब्रेरी फ़ाइल जनरेट करते समय, लाइब्रेरी का .dex जनरेट होता है. साथ ही, इसे .jack लाइब्रेरी फ़ाइल में प्री-डेक्स के तौर पर सेव किया जाता है.
कंपाइल करते समय, Jack हर लाइब्रेरी के प्री-डेक्स का फिर से इस्तेमाल करता है. सभी लाइब्रेरी पहले से डेक्स की गई हैं.
 
 
चौथी इमेज. प्री-डेक्स वाली जैक लाइब्रेरी.
अगर कंपाइलेशन में कोड छोटा करने, कोड को उलझाने या फिर से पैकेज करने की सुविधा का इस्तेमाल किया जाता है, तो Jack, लाइब्रेरी के प्री-डेक्स का फिर से इस्तेमाल नहीं करता.
इंक्रीमेंटल कंपाइलेशन
इंक्रीमेंटल कंपाइलेशन का मतलब है कि पिछली बार के कंपाइलेशन के बाद से, सिर्फ़ उन कॉम्पोनेंट को फिर से कंपाइल किया जाता है जिनमें बदलाव किया गया है. साथ ही, उन कॉम्पोनेंट की डिपेंडेंसी को भी फिर से कंपाइल किया जाता है. जब बदलाव कुछ कॉम्पोनेंट तक सीमित होते हैं, तो इंक्रीमेंटल कंपाइलेशन, पूरे कंपाइलेशन की तुलना में काफ़ी तेज़ी से हो सकता है.
इंक्रीमेंटल कंपाइलेशन की सुविधा डिफ़ॉल्ट रूप से बंद होती है. साथ ही, जब ऐप्लिकेशन को छोटा किया जाता है, कोड को छिपाया जाता है, फिर से पैकेज किया जाता है या मल्टी-डेक्स लेगसी की सुविधा चालू की जाती है, तब यह सुविधा अपने-आप बंद हो जाती है. इंक्रीमेंटल बिल्ड चालू करने के लिए, उस प्रोजेक्ट की Android.mk फ़ाइल में यह लाइन जोड़ें जिसे आपको इंक्रीमेंटल तरीके से बिल्ड करना है:
LOCAL_JACK_ENABLED := incremental
कोड का साइज़ कम करना और उसे अस्पष्ट बनाना
जैक, ProGuard कॉन्फ़िगरेशन फ़ाइलों का इस्तेमाल करके, कोड को छोटा करने और उसे उलटा-पलटा करने की सुविधा चालू करता है.
सामान्य विकल्पों में ये शामिल हैं:
- @
- -include
- -basedirectory
- -injars
- -outjars(सिर्फ़ एक आउटपुट जार फ़ाइल इस्तेमाल की जा सकती है)
- -libraryjars
- -keep
- -keepclassmembers
- -keepclasseswithmembers
- -keepnames
- -keepclassmembernames
- -keepclasseswithmembernames
- -printseeds
डेटा कम करने के विकल्पों में ये शामिल हैं:
- -dontshrink
डेटा को छिपाने के विकल्पों में ये शामिल हैं:
- -dontobfuscate
- -printmapping
- -applymapping
- -obfuscationdictionary
- -classobfuscationdictionary
- -packageobfuscationdictionary
- -useuniqueclassmembernames
- -dontusemixedcaseclassnames
- -keeppackagenames
- -flattenpackagehierarchy
- -repackageclasses
- -keepattributes
- -adaptclassstrings
इन विकल्पों को अनदेखा किया जाता है:
- -dontoptimize(जैक ऑप्टिमाइज़ नहीं करता)
- -dontpreverify(जैक पहले से पुष्टि नहीं करता)
- -skipnonpubliclibraryclasses
- -dontskipnonpubliclibraryclasses
- -dontskipnonpubliclibraryclassmembers
- -keepdirectories
- -target
- -forceprocessing
- -printusage
- -whyareyoukeeping
- -optimizations
- -optimizationpasses
- -assumenosideeffects
- -allowaccessmodification
- -mergeinterfacesaggressively
- -overloadaggressively
- -microedition
- -verbose
- -dontnote
- -dontwarn
- -ignorewarnings
- -printconfiguration
- -dump
रीपैकेजिंग
जैक, रीपैकेजिंग के लिए jarjar कॉन्फ़िगरेशन फ़ाइलों का इस्तेमाल करता है. Jack, "rule" टाइप के नियमों के साथ काम करता है. हालांकि, यह "zap" या "keep" टाइप के नियमों के साथ काम नहीं करता.
मल्टीडेक्स की सुविधा
Jack में, बिल्ट-इन और लेगसी मल्टीडेक्स की सुविधा उपलब्ध है. डेक्स फ़ाइलों में 65 हज़ार से ज़्यादा मेथड नहीं हो सकते. इसलिए, 65 हज़ार से ज़्यादा मेथड वाले ऐप्लिकेशन को कई डेक्स फ़ाइलों में बांटना ज़रूरी है. ज़्यादा जानकारी के लिए, 64 हज़ार से ज़्यादा तरीकों वाले ऐप्लिकेशन के लिए मल्टीडेक्स की सुविधा चालू करना लेख पढ़ें
