جک زنجیره ابزار ساخت پیشفرض اندروید برای اندروید 6.0 - 8.1 است
جک یک زنجیره ابزار اندروید است که منبع جاوا را در بایت کد Android dex کامپایل می کند. برای استفاده از جک لازم نیست کار متفاوتی انجام دهید - فقط از دستورات استاندارد makefile خود برای کامپایل درخت یا پروژه خود استفاده کنید. اندروید 8.1 آخرین نسخه ای است که از جک استفاده می کند.
درباره جک
جک همانطور که در شکل 1 نشان داده شده است کار می کند.
شکل 1. نمای کلی جک.
فرمت کتابخانه جک
جک فرمت فایل جک .jack
خود را دارد که حاوی کد dex از پیش کامپایل شده برای کتابخانه است که امکان کامپایل سریعتر را فراهم می کند (pre-dex).
شکل 2. محتویات فایل کتابخانه جک.
جیل
همانطور که در شکل زیر نشان داده شده است، ابزار Jill کتابخانه های .jar
موجود را به فرمت کتابخانه جدید ترجمه می کند.
شکل 3. گردش کار برای وارد کردن یک کتابخانه .jar
موجود.
سرور کامپایل جک
اولین باری که از جک استفاده می شود، یک سرور کامپایل محلی جک را روی رایانه شما راه اندازی می کند. این سرور:
- سرعت ذاتی را به ارمغان می آورد زیرا از راه اندازی یک میزبان جدید JRE JVM، بارگذاری کد جک، تنظیم اولیه جک و گرم کردن JIT در هر کامپایل جلوگیری می کند. همچنین زمان های کامپایل بسیار خوبی را در طول کامپایل های کوچک (مثلاً در حالت افزایشی) فراهم می کند.
- یک راه حل کوتاه مدت برای کنترل تعداد کامپایل های جک موازی است. سرور از بارگذاری بیش از حد رایانه شما (مشکل حافظه یا دیسک) جلوگیری می کند زیرا تعداد کامپایل های موازی را محدود می کند.
سرور جک خود را پس از مدت زمان بیکاری و بدون کامپایل خاموش می کند. از دو پورت TCP در رابط لوکال هاست استفاده می کند و به صورت خارجی در دسترس نیست. تمام پارامترها (تعداد کامپایلهای موازی، مهلت زمانی، تعداد پورتها و غیره) را میتوان با ویرایش فایل $HOME/.jack
تغییر داد.
فایل $HOME/.jack
فایل $HOME/.jack
شامل تنظیمات زیر برای متغیرهای سرور جک در یک دستور کامل bash است:
-
SERVER=true
ویژگی سرور جک را فعال می کند. -
SERVER_PORT_SERVICE=8072
شماره پورت TCP سرور را برای اهداف کامپایل تنظیم می کند. -
SERVER_PORT_ADMIN=8073
شماره پورت TCP سرور را برای اهداف مدیریتی تنظیم می کند. -
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 را در هاست تنظیم میکند. به طور پیش فرض، این متغیر می تواند توسط متغیر محیطی بارگذاری شود.
عیب یابی مجموعه های جک
مشکل | اقدام |
---|---|
رایانه شما در حین کامپایل کردن پاسخ نمی دهد یا با خطای کامپایل های جک در خطای «فقدان حافظه» مواجه می شوید. | با ویرایش $HOME/.jack و تغییر SERVER_NB_COMPILE به مقدار کمتر، تعداد کامپایلهای جک همزمان را کاهش دهید. |
کامپایلها در سرور پسزمینه راهاندازی نمیشود | محتمل ترین علت این است که پورت های TCP قبلاً در رایانه شما استفاده شده است. با ویرایش $HOME/.jack (متغیرهای SERVER_PORT_SERVICE و SERVER_PORT_ADMIN ) پورت ها را تغییر دهید. برای رفع انسداد وضعیت، سرور کامپایل جک را با ویرایش $HOME/.jack و تغییر SERVER به false غیرفعال کنید. متأسفانه این امر به طور قابل توجهی سرعت کامپایل شما را کند می کند و ممکن است مجبور شوید make -j با کنترل بار راه اندازی کنید (گزینه -l از make ). |
کامپایل بدون هیچ پیشرفتی گیر می کند | برای رفع انسداد، سرور پسزمینه جک را با استفاده از jack-admin kill-server بکشید، سپس دایرکتوریهای موقت موجود در jack-$USER دایرکتوری موقت خود را حذف کنید ( /tmp یا $TMPDIR ). |
لاگ جک را پیدا کنید
اگر دستور 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"
از دستورات استاندارد makefile برای کامپایل درخت (یا پروژه خود) و پیوست کردن خروجی و خطای استاندارد استفاده کنید. برای حذف گزارشهای ساخت دقیق، اجرا کنید:
unset ANDROID_JACK_EXTRA_ARGS
محدودیت های جک
به طور پیش فرض، سرور جک می تواند تنها توسط یک کاربر در رایانه استفاده شود. برای پشتیبانی از کاربران اضافی، شماره پورت های مختلف را برای هر کاربر انتخاب کنید و SERVER_NB_COMPILE
را بر اساس آن تنظیم کنید. همچنین می توانید با تنظیم SERVER=false
در $HOME/.jack
سرور جک را غیرفعال کنید. کامپایل CTS به دلیل ادغام فعلی vm-tests-tf
کند است. ابزارهای دستکاری بایت کد (مانند JaCoCo) پشتیبانی نمی شوند.
از جک استفاده کن
جک از زبان برنامه نویسی جاوا 1.7 پشتیبانی می کند و ویژگی های اضافی توضیح داده شده در زیر را ادغام می کند.
پیش دکس
هنگام تولید یک فایل کتابخانه جک، .dex
کتابخانه تولید و در داخل فایل کتابخانه .jack
به عنوان پیش دکس ذخیره می شود. هنگام کامپایل، جک از پیش دکس هر کتابخانه دوباره استفاده می کند. همه کتابخانه ها از پیش دکس شده اند.
شکل 4. کتابخانه های جک با پیش دکس.
جک از پیشدکس کتابخانه استفاده مجدد نمیکند اگر در مجموعه از کوچکشدن، مبهمسازی یا بستهبندی مجدد استفاده شود.
تالیف افزایشی
کامپایل افزایشی به این معنی است که فقط مؤلفه هایی که از آخرین کامپایل لمس شده اند (و وابستگی های آنها) دوباره کامپایل می شوند. زمانی که تغییرات محدود به مجموعهای از مؤلفهها باشد، کامپایل افزایشی میتواند به طور قابل توجهی سریعتر از کامپایل کامل باشد.
کامپایل افزایشی بهطور پیشفرض غیرفعال است (و بهطور خودکار در صورت فعال شدن کوچکشدن، مبهمسازی، بستهبندی مجدد یا چند dex قدیمی غیرفعال میشود). برای فعال کردن ساختهای افزایشی، خط زیر را به فایل Android.mk
پروژهای که میخواهید به صورت تدریجی بسازید اضافه کنید:
LOCAL_JACK_ENABLED := incremental
کوچک شدن و تیرگی
جک از فایل های پیکربندی ProGuard برای فعال کردن کوچک شدن و مبهم کردن استفاده می کند.
گزینه های رایج شامل موارد زیر است:
-
@
-
-include
-
-basedirectory
-
-injars
-
-outjars
(فقط 1 شیشه خروجی پشتیبانی می شود) -
-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 برای بسته بندی مجدد استفاده می کند. در حالی که جک با انواع قانون "قاعده" سازگار است، با انواع قانون "zap" یا "حفظ" سازگار نیست.
پشتیبانی از Multidex
جک پشتیبانی داخلی و قدیمی چند دکس را ارائه می دهد. از آنجایی که فایلهای dex به روشهای 65K محدود میشوند، برنامههایی با روشهای بیش از 65K باید به چندین فایل dex تقسیم شوند. برای جزئیات بیشتر، به Enable multidex برای برنامه هایی با روش های بیش از 64K مراجعه کنید