1. 工具篇 —— AIDEGen + Android Studio
AIDEGen,我叫它 “爱得跟”,大概是 Android10 中,google 推出的一个工具,用于方便开发者运用 IDE 来查看和修正体系源码。AIDEGen + Android Studio 十分适合用于阅览与修正 Android 体系 Java 代码。
运用 “爱得跟” 之前咱们需要做一些准备工作,编译 sdk:
source build/envsetup.sh
lunch sdk-eng
# or
#lunch sdk-userdebug
# or
#lunch sdk-user
make sdk
接着咱们需要去 google 官方下载 Android Studio,并将其放到 /opt 目录下。这推荐运用 3.6.3 版别,与咱们的 Android10_r41 更为匹配。
接下来,挑选咱们的方针 Product:
source build/envsetup.sh
lunch aosp_x86_64-eng #也可所以其他 product
做好以上准备工作后,咱们就能够翻开体系模块了,:
# Settings 是体系运用 设置
aidegen Settings -i s # -i 表明运用ide,s 表明 Android Studio
# 也能够翻开一个途径,保证这个途径下有 Android.bp 或许 Android.mk 即可
aidegen frameworks/base/services -i s
稍作等待,Android Studio 就翻开了,不过现在还不能直接运用,咱们还需要做一些基本的装备:
Android Studio 翻开后,右下角会呈现一个提示框(如果没有呈现,点击 file -> Invalidate Caches -> Invalidate and Restart):
点击 Configure,呈现以下界面:
点击 ok 即可。
接着装备 jdk 和 sdk,点击 file -> Project Structure:
接着点击 + 号:
点击 Add JDK
:
挑选源码下的 prebuilts/jdk/jdk9/linux-x86
,然后点击 ok:
接着将 name 修正为 aosp10-jdk9,然后点击右下角 apply:
接着点击 + 号,增加 Android SDK:
挑选体系源码目录下的 out/host/linux-x86/sdk/sdk/android-sdk_eng.zzh0838_linux-x86
(最终一个文件夹的姓名和你的用户名相关,你的和我的可能不一样),然后点击 ok:
接着 Java SDK 挑选刚刚增加的 aosp10-jdk9,点击 ok:
接着,修正 skd 的姓名为 aosp10-android-sdk29:
点击 ok 即可。
接着咱们需要装备项目的 sdk,点击 file -> Project Structure,点击左边 Project,右侧 SDK 选项挑选 aosp10-android-sdk:
点击左边 Modules,中心挑选 Settings,右侧 Module SDK 挑选 Project SDK:
接着,中心挑选 dependencies-Settings,右侧 Module SDK 挑选 Project SDK:
最终点击 apply,项目开始重新索引,项目内绝大部分类办法变量均可正确跳转。
至此,装备完成。
2. 手法篇 —— Java 源码的阅览
Java 源码咱们一般经过以下两种办法阅览:
- Log + 打印调用栈
- AIDEGen + Android Studio + 断点调试
针对发动相关的源码,一般是运用第一种办法阅览,接下来咱们来看看如何阅览体系发动过程中的重要进程 SystemServer:
首先找到 SystemServer:
#源码根目录下
cd frameworks
find . -name "SystemServer*"
./base/cmds/svc/src/com/android/commands/svc/SystemServerCommand.java
./base/services/java/com/android/server/SystemServer.java
./base/services/core/java/com/android/server/SystemServerInitThreadPool.java
# aidengen 翻开
aidegen frameworks/base/services
在 Android Studio 中咱们翻开 SystemServer.java,找到 main 办法,并增加下面的代码:
public static void main(String[] args) {
//经过打印 log 了解程序的运转状况
Log.d("yuandaima", "SystemServer is starting");
//经过打印仓库了解办法的调用途径
printStackTrace(Thread.currentThread());
new SystemServer().run();
}
//打印调用仓库的办法
public static void printStackTrace(Thread thread) {
for (StackTraceElement e : thread.getStackTrace()) {
Log.d("yuandaima", e.toString());
}
}
接着咱们编译体系,开启模拟器,然后获取日志信息:
rice14:/ # logcat | grep "yuandaima"
05-10 21:37:04.719 1641 1641 D yuandaima: SystemServer is starting
05-10 21:37:04.720 1641 1641 D yuandaima: dalvik.system.VMStack.getThreadStackTrace(Native Method)
05-10 21:37:04.721 1641 1641 D yuandaima: java.lang.Thread.getStackTrace(Thread.java:1720)
05-10 21:37:04.721 1641 1641 D yuandaima: com.android.server.SystemServer.printStackTrace(SystemServer.java:350)
05-10 21:37:04.721 1641 1641 D yuandaima: com.android.server.SystemServer.main(SystemServer.java:362)
05-10 21:37:04.721 1641 1641 D yuandaima: java.lang.reflect.Method.invoke(Native Method)
05-10 21:37:04.721 1641 1641 D yuandaima: com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
05-10 21:37:04.721 1641 1641 D yuandaima: com.android.internal.os.ZygoteInit.main(ZygoteInit.java:908)
经过打日志咱们能够了解体系程序的运转状况以及一些关键参数,经过调用仓库咱们能够了解程序运转过程中办法的一个调用流程。
非发动相关的源码,通常结合两种办法来阅览。接下来咱们看看如何断点调试体系 App:
首先,咱们开一个新的终端,翻开模拟器:
source build/envsetup.sh
lunch aosp_x86_64-eng
emulator
接着咱们在 Settings/AndroidManifest.xml 查找到 Settings App 的首 Activity 为 SettingsHomepageActivity,咱们在其 onCreate 出打一个断点:
接着在 Android 模拟器中翻开 Settings 运用。
接着点击 android studio 的 debug 按钮:
在弹出的窗口中,顺次挑选 Settings 和 com.android.settings,然后点击 ok:
在模拟器中,点击回来键,再次进入 Settings 运用,即可进入调试界面:
接着咱们就能够顺利的进行调试了。
关于
如果你对 Framework 感兴趣或许正在学习 Framework,能够参考我总结的Android Framework 学习路线指南,也可关注我的微信大众号,我会在大众号上继续分享我的经历,帮助正在学习的你少走一些弯路。学习过程中如果你有疑问或许你的经历想要分享给我们能够增加我的微信,我拉你进技术交流群。