Android SO加载深度剖析:从初始化到链接详解

需积分: 50 7 下载量 139 浏览量 更新于2024-07-18 收藏 2.07MB PDF 举报
本文是一篇深入解析Android系统动态链接库(.so)加载过程的文章,作者ManyFace于2016年2月7日撰写,主要针对的是Android L版本。文章首先介绍了Java层的`System.loadLibrary()`接口,这是Android应用程序调用动态链接库的主要入口点。 在Java层,`System.loadLibrary(libName)`函数会调用`Runtime.getRuntime().loadLibrary(libName, VMStack.getCallingClassLoader())`。`Runtime.loadLibrary()`进一步执行`Runtime.doLoad()`,而`doLoad()`实际上是调用了`nativeLoad()`,这涉及到了本地方法的加载机制。 `loadLibrary()`函数在内部首先尝试查找并加载.so文件,这个过程分为三个步骤: 1. **初始化阶段**:`find_libraries()`函数的第一部分,它负责初始化查找路径,可能包括系统目录、应用私有目录等,并根据指定的类加载器搜索相关的.so文件。 2. **载入so到内存**:接着是`load_library()`的两个子部分。首先,`load_library()`打开.so文件,这一步涉及到文件系统的访问和内存映射。然后,它将.so的内容映射到应用程序的地址空间,以便后续的处理。 3. **链接阶段**:`load_library()`的第三个部分,即解析dynamic section,这部分是关键,因为它涉及到符号表解析,确保Java中的方法与.so中的函数进行正确的关联。链接过程中,Android的链接器(linker)会查找函数地址并创建符号引用,这对于跨语言通信至关重要。 文章建议读者对ELF文件格式有一定的了解,因为Android的动态链接过程与这种可执行和链接格式密切相关。此外,文章承认可能存在分析不足或错误,鼓励读者提出宝贵的意见和指正。 本文通过详细的源码分析,揭示了从Java层到Native层,特别是.so文件从被请求到最终加载并完成链接的完整流程,为开发者提供了深入了解Android系统动态链接库加载机制的深入指南。