一、新建 Remote JVM Debug
1. 新建 Configuration 入口
2、TransformServer Configuration
從入口進入到下圖頁面奠宜,點擊左上角 “+” 號新建 Remote JVM Debug ,給 configuration 命名普监,默認(rèn) Unnamed俱饿。頁面中其他參數(shù)全部默認(rèn)。
3沮脖、Debug 插件關(guān)聯(lián)的 Task
./gradlew build -Dorg.gradle.debug=true --no-daemon
在 AS 終端執(zhí)行該命令金矛,將會卡在 Starting Daemon。如果執(zhí)行命令出現(xiàn)如下錯誤勺届,是因為端口占用的問題驶俊。需要殺死占用端口的進程。
ERROR: transport error 202: bind failed: Address already in use
ERROR: JDWP Transport dt_socket failed to initialize, TRANSPORT_INIT(510)
JDWP exit error AGENT_ERROR_TRANSPORT_INIT(197): No transports initialized [./open/src/jdk.jdwp.agent/share/native/libjdwp/debugInit.c:732]
mac 查看端口免姿、殺死進程
// 5005為端口
lsof -i tcp:5005
// 9901 為Pid
kill -9 9901
這里再特別說明一下該節(jié)中命令中的 --no-daemon 參數(shù)饼酿,它涉及到 gradle 守護進程這一概念。要添加這個參數(shù)的原因是胚膊,如果不添加該參數(shù)嗜湃,在調(diào)試過程中發(fā)現(xiàn)斷點走不到奈应,構(gòu)建流程就走完了。這個參數(shù)的作用是告訴 gradle 不使用守護進程進行構(gòu)建购披。
4杖挣、添加斷點、Debug TransformServer
如圖所示刚陡,選中我們新建的 TransformServer Configuration惩妇,然后點擊調(diào)試按鈕,然后就會執(zhí)行到斷點處筐乳。
二歌殃、探索過程中遇到的其他問題
1. Android Studio Remote Debug Unable to open debugger port 5005
在執(zhí)行 Debug TransformServer 中發(fā)生這一異常。出現(xiàn)這個問題的原因蝙云,一般是端口被占用氓皱,但是發(fā)現(xiàn)并沒有被占用。這個時候解決方法是將 App module 運行起來勃刨,然后再 debug 即可正常波材。
2. 斷點不是每一次都能正常走到
需要手動 build -> clean