NDK 在 Android 中如何工作 - NDK、JNI 等的使用顺序是什么?
How does NDK work in Android - What is the order that NDK, JNI etc are used?
Java、NDK、JNI、JVM、C/C++ 代码等在 android 项目中如何相互关联?
我想知道发生了什么,例如Java 代码运行 NDK 方法,NDK 使用 JNI 库或发生的任何事情。另外NDK和JNI有什么区别
抱歉,如果这个问题措辞不当,我只是对如何在 Android 项目
中实施 NDK 感到困难
NDK 用于将C/C++/asm 代码编译成二进制文件。您可以使用 NDK 做很多事情,例如编译可执行文件、静态预构建...但最后,在 Android 应用程序的上下文中,您会获得一个或多个 .so 文件(共享 object 个库)。
从Java开始,您可以加载此类.so文件和在其中实现的映射函数。有一种特定情况,其中 Android 应用程序项目仅包含 C/C++ 代码(请参阅来自 NDK 的 native-activity 示例),但这是还是一样的原则:.so 文件在 ART 或 Dalvik 上下文中加载。
Android 应用程序中的任何内容都在 Dalvik 虚拟机或 ART 的上下文中执行。为了将您的 C/C++ 代码与此环境集成,您可以使用 JNI(Java 本机接口 )。
你首先从JNI机制开始使用JNI:当你加载一个.so文件时,它的JNI_OnLoad()函数被调用,如果它存在并且以Java_开头的函数被映射到相应的 Java 方法。这些方法将在 Java classes 中声明,并使用关键字 native 来指定它们的实现来自 .so 文件。使用 System.loadLibrary() 加载 .so 文件,通常来自 Java class 的静态块,其方法声明为 原生.
在运行时,当 Java 执行到达一个实现为 native 的方法时,即。在一个 .so 文件中,并且已经加载了该 .so 文件,直接执行此本机实现。当它 returns 时,Java 代码执行继续。
JNI 还为您提供了 jni.h header,它为您提供了访问 Java 环境(JavaVM*、JNIEnv*)的方法,因此您可以操纵、创建和访问 Java 原语(jint、jlong...)、objects(jobject、jclass..)、异常(jthrowable)等.
要使用 System.loadLibrary 正确打包、安装和加载,您的 .so 文件必须放在特定位置:
libs/CPU_ABI 在 eclipse 项目中
jniLibs/CPU_ABI 在 Android Studio 项目中
jni/CPU_ABI 在 AAR
中
当应用程序打包为 APK 时,库位于其 lib/CPU_ABI 文件夹中。
在安装过程中,目标平台的库被安装到 <5.0 设备上的 nativeLibraryPath 中,以及应用程序的 legacyNativeLibraryDir/CPU_ARCH 在 >=5.0 设备上。
其中 CPU_ABI 是以下任何一个:armeabi、armeabi-v7a、arm64-v8a、x86、x86_64、mips、 mips64。取决于您的目标架构和您的库已被编译。
Java、NDK、JNI、JVM、C/C++ 代码等在 android 项目中如何相互关联?
我想知道发生了什么,例如Java 代码运行 NDK 方法,NDK 使用 JNI 库或发生的任何事情。另外NDK和JNI有什么区别
抱歉,如果这个问题措辞不当,我只是对如何在 Android 项目
中实施 NDK 感到困难NDK 用于将C/C++/asm 代码编译成二进制文件。您可以使用 NDK 做很多事情,例如编译可执行文件、静态预构建...但最后,在 Android 应用程序的上下文中,您会获得一个或多个 .so 文件(共享 object 个库)。
从Java开始,您可以加载此类.so文件和在其中实现的映射函数。有一种特定情况,其中 Android 应用程序项目仅包含 C/C++ 代码(请参阅来自 NDK 的 native-activity 示例),但这是还是一样的原则:.so 文件在 ART 或 Dalvik 上下文中加载。
Android 应用程序中的任何内容都在 Dalvik 虚拟机或 ART 的上下文中执行。为了将您的 C/C++ 代码与此环境集成,您可以使用 JNI(Java 本机接口 )。
你首先从JNI机制开始使用JNI:当你加载一个.so文件时,它的JNI_OnLoad()函数被调用,如果它存在并且以Java_开头的函数被映射到相应的 Java 方法。这些方法将在 Java classes 中声明,并使用关键字 native 来指定它们的实现来自 .so 文件。使用 System.loadLibrary() 加载 .so 文件,通常来自 Java class 的静态块,其方法声明为 原生.
在运行时,当 Java 执行到达一个实现为 native 的方法时,即。在一个 .so 文件中,并且已经加载了该 .so 文件,直接执行此本机实现。当它 returns 时,Java 代码执行继续。
JNI 还为您提供了 jni.h header,它为您提供了访问 Java 环境(JavaVM*、JNIEnv*)的方法,因此您可以操纵、创建和访问 Java 原语(jint、jlong...)、objects(jobject、jclass..)、异常(jthrowable)等.
要使用 System.loadLibrary 正确打包、安装和加载,您的 .so 文件必须放在特定位置:
libs/CPU_ABI 在 eclipse 项目中
jniLibs/CPU_ABI 在 Android Studio 项目中
jni/CPU_ABI 在 AAR
中
当应用程序打包为 APK 时,库位于其 lib/CPU_ABI 文件夹中。
在安装过程中,目标平台的库被安装到 <5.0 设备上的 nativeLibraryPath 中,以及应用程序的 legacyNativeLibraryDir/CPU_ARCH 在 >=5.0 设备上。
其中 CPU_ABI 是以下任何一个:armeabi、armeabi-v7a、arm64-v8a、x86、x86_64、mips、 mips64。取决于您的目标架构和您的库已被编译。