andriod zygote
Posted stachal
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了andriod zygote相关的知识,希望对你有一定的参考价值。
/system/bin/app_process64 作为service 被启动,启动后comm:改成main ,cmdline 改成 zygote ,
main -> runtime.start( com.android.internal.os.ZygoteInit) 调用在frameworks/base/core/jni/AndroidRuntime.cpp文件中的父类 AndriodRuntime::start () {启动虚拟机) } }
c语言里通过JNI语法直接调用了java语言的 com.android.internal.os.ZygoteInit 类在 frameworks/base/core/java/com/android/internal/os/ZygoteInit.java
main-> startSystemServer() -> Zygote.forkSystemServer { nativeForkSystemServer{} }
-> handleSystemServerProcess {}
nativeForkSystemServer : JAVA里面调用C ,jni 实现在frameworks/base/core/jni/com_android_internal_os_Zygote.cpp下的com_android_internal_os_Zygote_nativeForkSystemServer() : fork 出来的进程进程,改了 comm 到system_server
-> ForkAndSpecializeCommon -> SetThreadName-> pthread_setname_np
以上是关于andriod zygote的主要内容,如果未能解决你的问题,请参考以下文章
100天精通Andriod逆向——第6天:Andriod 开发入门