Android 源码如何导入 Android Studio?踩坑与解决方案详解

版权归作者所有,如有转发,请注明文章出处:cyrus-studio.github.io/blog/

前言

需要先把 Android 源码编译一遍,Android 源码编译参考这篇文章:解决90%踩坑问题!LineageOS 源码下载与编译保姆级教程

idegen.sh 脚本生成项目文件,一步步排除导入过程中常见的坑点,将 Android 源码集成进 Android Studio 环境中,从而实现高效阅读与调试系统代码。

生成 android.ipr 文件

  1. 进入到下面的目录
bash 复制代码
cd ./development/tools/idegen
  1. 使用 mm 命令对当前目录 make,构建 idegen 模块

    mm

执行完成后会在 out 目录生成一个 idegen.jar 文件

  1. 回到 android 源码根目录,执行 idegen.sh 脚本(需要管理员权限)
bash 复制代码
# 回到 android 源码根目录
croot
# 执行 idegen.sh 脚本
sudo ./development/tools/idegen/idegen.sh
  1. 执行完成后会生成一个 android.ipr 文件,用 android studio 打开这个 android.ipr 文件就可以完成 android 源码的导入了

运行 idegen.sh 脚本时遇到的问题

在运行 development/tools/idegen/idegen.sh 脚本时遇到的问题

1. 文件系统循环

find: File system loop detected 错误表示在使用 find 命令时遇到了符号链接循环。这通常不会导致脚本失败,但确实会产生一些额外的警告信息。

2. Java 版本不匹配

错误信息 java.lang.UnsupportedClassVersionError 表示 Main 类是用较新的 Java 版本编译的,而当前运行的 Java 版本较旧。

vbnet 复制代码
find: File system loop detected; 'out/target/product/gemini/root/d/device_component' is part of the same file system loop as 'out/target/product/gemini/root/d'.
find: File system loop detected; 'out/target/product/gemini/recovery/root/d/device_component' is part of the same file system loop as 'out/target/product/gemini/recovery/root/d'.
find: File system loop detected; 'out/target/product/gemini/obj/PACKAGING/target_files_intermediates/lineage_gemini-target_files/RECOVERY/RAMDISK/d/device_component' is part of the same file system loop as 'out/target/product/gemini/obj/PACKAGING/target_files_intermediates/lineage_gemini-target_files/RECOVERY/RAMDISK/d'.
find: File system loop detected; 'out/target/product/gemini/obj/PACKAGING/target_files_intermediates/lineage_gemini-target_files/ROOT/d/device_component' is part of the same file system loop as 'out/target/product/gemini/obj/PACKAGING/target_files_intermediates/lineage_gemini-target_files/ROOT/d'.
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.UnsupportedClassVersionError: Main has been compiled by a more recent version of the Java Runtime (class file version 61.0), this version of the Java Runtime only recognizes class file versions up to 52.0
        at java.lang.ClassLoader.defineClass1(Native Method)
        at java.lang.ClassLoader.defineClass(ClassLoader.java:756)
        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
        at java.net.URLClassLoader.defineClass(URLClassLoader.java:473)
        at java.net.URLClassLoader.access$100(URLClassLoader.java:74)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:369)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:363)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:362)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:418)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:352)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
        at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:621)
  1. 升级 Java 版本

你需要安装一个较新的 Java 版本(至少 Java 17)来解决这个问题。可以通过以下步骤完成

卸载旧的 Java 版本(如果有必要)

arduino 复制代码
sudo apt-get remove openjdk-8-jdk

安装新的 Java 版本(以安装 OpenJDK 17 为例)

sql 复制代码
sudo apt-get update
sudo apt-get install openjdk-17-jdk

验证安装

复制代码
java -version

你应该看到类似以下输出

arduino 复制代码
openjdk version "17.0.x" 2021-09-14
  1. 重新运行 idegen.sh

在升级 Java 版本之后,重新运行 idegen.sh 脚本

bash 复制代码
sudo development/tools/idegen/idegen.sh

这会在项目根目录生成 IntelliJ 项目文件 (.ipr)。

导入 android studio

最后,就是打开 android studio,【File】【Open】【选择在源码根目录下的android.ipr】就可以了

导入完成

相关推荐
SharpCJ5 小时前
Android 开发者为什么必须掌握 AI 能力?端侧视角下的技术变革
android·ai·aigc
_李小白6 小时前
【OSG学习笔记】Day 38: TextureVisitor(纹理访问器)
android·笔记·学习
JJay.6 小时前
Kotlin 高阶函数学习指南
android·开发语言·kotlin
jinanwuhuaguo6 小时前
截止到4月8日,OpenClaw 2026年4月更新深度解读剖析:从“能力回归”到“信任内建”的范式跃迁
android·开发语言·人工智能·深度学习·kotlin
JJay.7 小时前
Android Kotlin 协程使用指南
android·开发语言·kotlin
彬sir哥7 小时前
android studio 如何关闭代理
android studio·proxy
BLUcoding8 小时前
Android 布局介绍
android
summerkissyou19878 小时前
android-蓝牙-状态和协议值总结及监听例子
android·蓝牙
徒 花8 小时前
数据库知识复习05
android·数据库
提子拌饭13310 小时前
番茄时间管理:鸿蒙Flutter 实现的高效时间管理工具
android·flutter·华为·架构·开源·harmonyos·鸿蒙