Android native and Java 互调记录

     安卓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的基础。

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值