安卓framework使用java和c++(或者c)语言共同开发,为了使java和c无缝切换,安卓定义了一套native机制(源于java语言的native机制)。
在此已InputMangerServie服务为例,记录一下两种语言无缝切换的方式,方便于以后开发。
当安卓linux内核启动以后会读取init.rc等rc文件去加载一些进程,这些进程包含安卓的adbd,bootanimation,zygote等,但是在启动zygote时会首先启动runtime,runtime作为zygote的一部分占据重要地位,我们系统的so库预加载,以及jvm等加载都要靠他,可见它的重要性。当然java层与native层的切换离不开它,或者说整个java环境离不开他。zygote的启动方式为
service zygote /system/bin/app_process -Xzygote /system/bin --zygote --start-system-server
socket zygote stream 666
onrestart write /sys/android_power/request_state wake
onrestart write /sys/power/state on
onrestart restart media
onrestart restart netd
我们看到zygote就是app_process这个可执行文件,其位于frameworks/base/cmds/app_process目录其Android.mk定义如下:
include $(CLEAR_VARS)
LOCAL_SRC_FILES:= $(app_process_src_files)
LOCAL_LDFLAGS_32 := $(app_process_ldflags_32)
LOCAL_LDFLAGS_64 := $(app_process_ldflags_64)
LOCAL_SHARED_LIBRARIES := $(app_process_common_shared_libs)
LOCAL_WHOLE_STATIC_LIBRARIES := $(app_process_common_static_libs)
LOCAL_MODULE:= app_process
LOCAL_MULTILIB := both
LOCAL_MODULE_STEM_32 := app_process32
LOCAL_MODULE_STEM_64 := app_process64
LOCAL_CFLAGS += $(app_process_cflags)
ifeq ($(SANITIZE_LITE),true)
LOCAL_MODULE_PATH := $(TARGET_OUT_EXECUTABLES)/asan
LOCAL_REQUIRED_MODULES := asanwrapper
endif
include $(BUILD_EXECUTABLE)
其中可根据编译的版本生成32位或者64位可执行文件。
我们进入这个进程的main函数可以看到如下代码:
int main(int argc, char* const argv[])
{
std::string bootmode = GetProperty("ro.bootmode", "");
if ((strncmp(bootmode.c_str(), "ffbm-00", 7) == 0)
|| (strncmp(bootmode.c_str(), "ffbm-01", 7) == 0)) {
return 0;
}
if (!LOG_NDEBUG) {
String8 argv_String;
for (int i = 0; i < argc; ++i) {
argv_String.append("\"");
argv_String.append(argv[i]);
argv_String.append("\" ");
}
ALOGV("app_process main with argv: %s", argv_String.string());
}
AppRuntime runtime(argv[0], computeArgBlockSize(argc, argv));
// Process command line arguments
// ignore argv[0]
argc--;
argv++;
...................................此处省略一万字……………^_^
if (zygote) {
runtime.start("com.android.internal.os.ZygoteInit", args, zygote);
} else if (className) {
runtime.start("com.android.internal.os.RuntimeInit", args, zygote);
} else {
fprintf(stderr, "Error: no class name or --zygote supplied.\n");
app_usage();
LOG_ALWAYS_FATAL("app_process: no class name or --zygote supplied.");
}
}
前面的启动模式和log基本可以忽略不是正常开机的流程,除去他们可以看到最先调用的就是runtime。
而且zygote的启动后面也是靠它来完成的,可以说runtime才是zygote的技术,整个安卓framework的基础。