NDK实战(一)—— JNI原理(上)

本文详细介绍了JNI(Java Native Interface)的原理,包括C/C++代码的编译、链接生成动态链接库,系统如何识别native方法,以及动态链接库何时加载到JVM中。在Android NDK开发中,理解这些步骤对于解决问题至关重要。
摘要由CSDN通过智能技术生成

JNI原理(上)

一、编译

CPU只能识别0101这样的二进制文件,C/C++需要经过一层编译转成二进制文件。在Windows平台上会转成xxx.obj文件,在Linux平台会转成xxx.o文件。此由过程编译器完成。

编译规则:
- Eclipse ====> GUN ====> Android.mk
- Android Studio ====> LLVM ====> CMakeLists.txt

二、链接

在Windows平台上,obj链接生成.dll文件,Linux生成.so文件。链接会执行检查,如果失败则抛出Link error的异常。

注:在NDK开发过程中需要声明引入哪些.c/.cpp文件以及链接哪些.so库。

三、系统如何识别native方法

编写两个方法,其中一个为native方法

    public static native void diff(String path, String patternPath, int fileNum);

    public static void javaDiff(String path, String patternPath, int fileNum) {
        
    }

使用javac编译该类(如果使用Kotlin则用kotlinc,需要到Github下载Kotlin编译器),获得一个.class文件,使用javap -v反编译该class文件,可以看到

 public static native void diff(java.lang.String, java.lang.String, int);
    descriptor: (Ljava/lang/String;Ljava/lang/String;I)V
    flags: ACC_PUBLIC, ACC_STATIC, ACC_NATIVE

  public static void javaDiff(java.lang.String, java.lang.String, int);
    descriptor: (Ljava/lang/String;Ljava/lang/String;I)V
    flags: ACC_PUBLIC, ACC_STATIC

native方法比普通方法多出一个 ACC_NATIVE 的标识

四、Native方法(动态链接库)什么时候加载到JVM里面

第一步,寻找链接库

loadLibrary(String libname)

方法进入,方法内部是调用了RunTime的 loadLibrary0

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

方法内ClassLoader会根据库名去寻找该库文件全路径

String filename = loader.findLibrary(libraryName);

继续进入 findLibrar

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值