JANI的注册
Zygote的启动流程
目的就是实现Java和native层的可以相互调用
service zygote /system/bin/app_process -Xzygote /system/bin --zygote --start-system-server
class main
socket zygote stream 660 root system
onrestart write /sys/android_power/request_state wake
onrestart write /sys/power/state on
onrestart restart media
onrestart restart netd
writepid /dev/cpuset/foreground/tasks
上面会直接启动app_main.cpp的main方法:
int main(int argc, char* const argv[])
{
if (strcmp(arg, "--zygote") == 0) {
zygote = true;
niceName = ZYGOTE_NICE_NAME;
}
if (strcmp(arg, "--zygote") == 0) {
zygote = true;
niceName = ZYGOTE_NICE_NAME;
}
if (zygote) {
runtime.start("com.android.internal.os.ZygoteInit", args, zygote);
}
}
上面的runtime 对象实际上就是
AppRuntime runtime(argv[0], computeArgBlockSize(argc, argv));
class AppRuntime : public AndroidRuntime 表示AppRuntime 继承自AndroidRuntime 。
void AndroidRuntime::start(const char* className, const Vector<String8>& options, bool zygote)
{
if (startReg(env) < 0) {
ALOGE("Unable to register all android natives\n");
return;
}
}
注册JNI方法:
/*
* Register android native functions with the VM.
*/
/*static*/ int AndroidRuntime::startReg(JNIEnv* env)
{
if (register_jni_procs(gRegJNI, NELEM(gRegJNI), env) < 0) {
env->PopLocalFrame(NULL);
return -1;
}
}
static int register_jni_procs(const RegJNIRec array[], size_t count, JNIEnv* env)
{
for (size_t i = 0; i < count; i++) {
if (array[i].mProc(env) < 0) {
#ifndef NDEBUG
ALOGD("----------!!! %s failed to load\n", array[i].mName);
#endif
return -1;
}
}
return 0;
}
static const RegJNIRec gRegJNI[] = {
REG_JNI(register_android_os_Binder),
}
static const JNINativeMethod gBinderMethods[] = {
{ "getCallingPid", "()I", (void*)android_os_Binder_getCallingPid },
{ "getCallingUid", "()I", (void*)android_os_Binder_getCallingUid },
{ "init", "()V", (void*)android_os_Binder_init },
}