اندروید استودیو برای پلتفرم (ASfP) یک دیباگر قدرتمند ارائه میدهد که به شما امکان میدهد:
- دستگاهی را برای اشکالزدایی انتخاب کنید.
- نقاط توقف را در کد جاوا، کاتلین، سی/سیپلاسپلاس و راست خود تنظیم کنید.
- متغیرها را بررسی و عبارات را در زمان اجرا ارزیابی کنید.
قبل از استفاده از اشکالزدا، باید نسخه ساختهشده خود را روی یک دستگاه یا شبیهساز فلش کنید.
اشکالزدایی فرآیند برنامه (جاوا/کاتلین)
برای اشکالزدایی فرآیند برنامه جاوا یا کاتلین:
نقاط توقف را در کد جاوا یا کاتلین خود در ASfP تنظیم کنید.
از منو، گزینهی Run > Attach Debugger to Android Process را انتخاب کنید.
در پنجرهی «انتخاب فرآیند» ، مطمئن شوید که نوع اشکالزدایی (Debug type) روی «فقط جاوا» (Java Only ) تنظیم شده باشد.
دستگاه خود را از لیست انتخاب کنید.
فرآیند برنامه خاصی را که میخواهید اشکالزدایی کنید، انتخاب کنید.
روی تأیید کلیک کنید.
برای رسیدن به نقاط توقف، با برنامه روی دستگاه خود تعامل کنید.
اشکالزدایی فرآیند سیستم (C/C++)
برای اشکالزدایی یک فرآیند سیستمی که با زبان C یا C++ نوشته شده است:
تأیید کنید که فقط یک دستگاه یا شبیهساز در حال اجرا دارید.
یک ترمینال باز کنید و
adb rootاز ریشه پرداخت AOSP خود اجرا کنید:bash adb root
نقاط توقف را در کد C/C++ خود در ASfP تنظیم کنید.
از منو، گزینهی Run > Attach Debugger to Android Process را انتخاب کنید.
در پنجرهی «انتخاب فرآیند» ، نوع اشکالزدایی (Debug type) را به «فقط بومی» (Native Only ) یا «دوگانه (Java + بومی)» (Dual (Java + Native)) تغییر دهید.
برای مشاهدهی فرآیندهای سیستم، گزینهی «نمایش همه فرآیندها» را علامت بزنید.
دستگاه خود را از لیست انتخاب کنید.
فرآیند سیستم خاصی را که میخواهید اشکالزدایی کنید (مانند
surfaceflingerیاsystem_server) انتخاب کنید.روی تأیید کلیک کنید.
برای رسیدن به نقاط شکست خود، با دستگاه تعامل کنید.
اشکالزدایی زنگزدگی
ASfP از اشکالزدایی Rust با استفاده از پروتکل آداپتور اشکالزدایی (DAP) به همراه LLDB پشتیبانی میکند. این بخش نحوه راهاندازی CodeLLDB به عنوان یک سرور آداپتور اشکالزدایی و اشکالزدایی کد Rust روی میزبان و روی یک دستگاه اندروید را شرح میدهد.
تنظیم CodeLLDB به عنوان سرور آداپتور اشکالزدایی
یک پیکربندی جدید برای Debug Adapter Protocol Run/Debug ایجاد کنید:
- از منو ، گزینهی اجرا > ویرایش پیکربندیها را انتخاب کنید.
- روی دکمه + کلیک کنید.
- پروتکل آداپتور اشکالزدایی را انتخاب کنید.
در تب سرور، روی ایجاد یک سرور جدید کلیک کنید.
در پنجرهی باز شده، روی Choose template کلیک کنید و CodeLLDB را از لیست انتخاب کنید.
پس از انتخاب الگوی CodeLLDB، سرور جدید با پیکربندی از پیش تعریف شده اضافه میشود.
- با انتخاب Verbose در منوی کشویی Trace ، ردیابی شفاهی (verbose tracing) را فعال کنید.
- یک متغیر محیطی اضافه کنید که مسیر
lldb-serverرا در فایلهای از پیش ساخته شده سورس اندروید شما مشخص کند:
LLDB_DEBUGSERVER_PATH=REPO_ROOT/prebuilts/clang/host/linux-x86/CLANG_VERSION/runtimes_ndk_cxx/x86_64/lldb-server ``` Replace `REPO_ROOT` with the absolute path to your Android source checkout. To find `CLANG_VERSION`, run the `get_clang_version.py` script from the root of your Android source tree: ```bash ./build/soong/scripts/get_clang_version.py- بخش
<<insert base directory>>را تغییر ندهید .
اشکالزدایی فایلهای باینری Rust روی میزبان
- برگه پیکربندی را در پیکربندی Debug Adapter Protocol Run/Debug خود باز کنید.
- گزینه «راهاندازی» (Launch) را به عنوان حالت اشکالزدایی (Debug Mode) انتخاب کنید.
- دایرکتوری کاری را بهروزرسانی کنید و فایل باینری مورد نظر برای اشکالزدایی را انتخاب کنید.
- برای ذخیره پیکربندی، روی تأیید کلیک کنید.
- با کلیک روی نماد اشکالزدایی در کنار پیکربندی، جلسه اشکالزدایی را آغاز کنید.
اولین باری که این را اجرا میکنید، CodeLLDB دانلود میشود. باید ردپاهای DAP را در کنسول ببینید. نقاط شکست تنظیم شده در کد Rust شما باید مطابق انتظار اعمال شوند.
اشکالزدایی فایلهای باینری Rust در دستگاه اندروید (حالت پیوست)
پیدا کردن PID: شناسه فرآیند (PID) برنامهای را که میخواهید روی دستگاه اندروید اشکالزدایی کنید، شناسایی کنید.
شروع lldb-server روی دستگاه: از ریشهی بررسی درخت سورس اندروید خود، اسکریپت
lldbclient.pyرا اجرا کنید و<PID>را با شناسهی فرآیند جایگزین کنید:lldbclient.py --setup-forwarding vscode-lldb -p <PID>این اسکریپت
lldb-serverصحیح را به دستگاه ارسال میکند، آن را راهاندازی میکند، پورت فورواردینگ (پورت میزبان ۵۰۳۹ به دستگاه) را تنظیم میکند و پیکربندی DAP JSON مورد نیاز برای مراحل بعدی را خروجی میدهد. این ترمینال را باز نگه دارید.آداپتور اشکالزدایی CodeLLDB را روی میزبان اجرا کنید:
- به دایرکتوری افزونه CodeLLDB بروید (پیشفرض:
~/.lsp4ij/dap/codelldb/extension/adapter). - متغیرهای محیطی مورد نیاز را تنظیم کرده و سرور آداپتور را راهاندازی کنید، و
REPO_ROOTوCLANG_VERSIONرا همانطور که در تنظیمات سرور تعیین شده است، جایگزین کنید:
# Sets PYTHONHOME env variable export PYTHONHOME=REPO_ROOT/prebuilts/clang/host/linux-x86/CLANG_VERSION/python3 # Tell the dynamic linker where to find python libs export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:REPO_ROOT/prebuilts/clang/host/linux-x86/CLANG_VERSION/python3/lib # Starts the CodeLLDB Debugger Adapter server on port 1234 ./codelldb --liblldb REPO_ROOT/prebuilts/clang/host/linux-x86/CLANG_VERSION/lib/liblldb.so --port 1234- به دایرکتوری افزونه CodeLLDB بروید (پیشفرض:
پیکربندی کلاینت ASfP DAP:
- به پیکربندی Debug Adapter Protocol Run/Debug در ASfP برگردید.
- برگه پیکربندی را انتخاب کنید.
- حالت اشکالزدایی را روی پیوست تنظیم کنید.
- آدرس را روی
localhostتنظیم کنید. - پورت را روی
1234تنظیم کنید. - خروجی JSON از دستور
lldbclient.py(مرحله 2) را در فیلد پارامترهای DAP (JSON) قرار دهید.
برای شروع جلسه اشکالزدایی، روی اشکالزدایی (Debug) کلیک کنید.
عیبیابی
- اگر
error: Connection shut down by remote side while waiting for reply to initial handshake packet، جلسه اشکالزدایی فعلی را خاتمه دهید وlldb-serverروی دستگاه و آداپتور CodeLLDB را روی میزبان مجدداً راهاندازی کنید.