Dalvik虚拟机中so的加载和JNI调用

本文详细介绍了Dalvik虚拟机加载so的过程,从System.loadLibrary到dvmLoadNativeCode,再到JNI函数注册。分析了主动注册与被动注册的区别,并探讨了Bridge的作用,以及如何在退出插件时卸载so和热修复中实现native函数的热替换。
摘要由CSDN通过智能技术生成

本文主要目的是搞清楚so加载和调用的整体脉络,以便遇到so相关的问题时做到心中有数,能迅速把握解决问题的大方向。

先抛出两个问题:
1. 退出插件时如何卸载so,以免内存占用越来越大?
2. 热修复中如何实现native函数的热替换?

这两个问题我会在文章结尾给出解决思路。

so是在System.loadLibrary中加载的,如下:

public static void loadLibrary(String libName) {
    Runtime.getRuntime().loadLibrary(libName, VMStack.getCallingClassLoader());
}

这里传入的ClassLoader正是调用System.loadLibrary的类的ClassLoader,通常为PathClassLoader。

再来看Runtime.loadLibrary的实现:

void loadLibrary(String libraryName, ClassLoader loader) {
    if (loader != null) {
        String filename = loader.findLibrary(libraryName);
        String error = nativeLoad(filename, loader);
        return;
    }

    String filename = System.mapLibraryName(libraryName);
    List<String> candidates = new ArrayList<String>();
    String lastError = null;
    for (String directory : mLibPaths) {
        String candidate = directory + filename;
        candidates.add(candidate);
        if (new File(candidate).exists()) {
            String error = nativeLoad(candidate, loader);
            if (error == null) {
                return;
            }
            lastError = error;
        }
    }
    ..........
}

这里主要做了两件事,首先去查找所有可能的路径判断so是否存在,如果存在就调用nativeLoad加载so。我们重点看so的加载:

static void Dalvik_java_lang_Runtime_nati
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风语

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值