Android KitKat 模拟器 native 库 JNI 错误(应用程序错误)

标签 android android-emulator java-native-interface dalvik android-4.4-kitkat

使用 Android 4.4.2 API 级别 19 模拟器测试我的应用程序时,首次调用 native 代码会导致崩溃。这是日志猫:

01-29 12:12:32.639: E/ALLOC(1232): Requiring 1228800bytes
01-29 12:12:32.639: D/dalvikvm(1232): Trying to load lib /data/app-lib/it.jcsoftmobile.snailcamera.snailcamerapro-1/liblowlevelpixelworks.so 0xb4cd9cc8
01-29 12:12:32.639: D/dalvikvm(1232): Added shared lib /data/app-lib/it.jcsoftmobile.snailcamera.snailcamerapro-1/liblowlevelpixelworks.so 0xb4cd9cc8
01-29 12:12:32.639: D/dalvikvm(1232): No JNI_OnLoad found in /data/app-lib/it.jcsoftmobile.snailcamera.snailcamerapro-1/liblowlevelpixelworks.so 0xb4cd9cc8, skipping init
01-29 12:12:32.679: E/dalvikvm(1232): JNI ERROR (app bug): negative buffer capacity: -5457750921690562560
01-29 12:12:32.679: I/dalvikvm(1232): "main" prio=5 tid=1 RUNNABLE
01-29 12:12:32.679: I/dalvikvm(1232):   | group="main" sCount=0 dsCount=0 obj=0xb4a2aca8 self=0xb70c4380
01-29 12:12:32.689: I/dalvikvm(1232):   | sysTid=1232 nice=0 sched=0/0 cgrp=apps handle=-1225698988
01-29 12:12:32.689: I/dalvikvm(1232):   | state=R schedstat=( 1140000000 1520000000 1339 ) utm=83 stm=31 core=0
01-29 12:12:32.729: I/dalvikvm(1232):   at it.jcsoftmobile.snailcamera.ImageLab.NativeAlloc(Native Method)

这是同一段代码、相同应用程序、相同屏幕尺寸模拟器的 logcat,...唯一不同的是 Android 版本 (4.3):

01-28 19:52:51.543: E/ALLOC(12661): Requiring 1228800bytes
01-28 19:52:51.563: D/dalvikvm(12661): Trying to load lib /data/app-lib/it.jcsoftmobile.snailcamera.snailcamerapro-1/liblowlevelpixelworks.so 0x416e2fd0
01-28 19:52:51.613: D/dalvikvm(12661): Added shared lib /data/app-lib/it.jcsoftmobile.snailcamera.snailcamerapro-1/liblowlevelpixelworks.so 0x416e2fd0
01-28 19:52:51.613: D/dalvikvm(12661): No JNI_OnLoad found in /data/app-lib/it.jcsoftmobile.snailcamera.snailcamerapro-1/liblowlevelpixelworks.so 0x416e2fd0, skipping init
01-28 19:52:51.922: D/dalvikvm(12661): GC_FOR_ALLOC freed 68K, 4% free 3447K/3584K, paused 302ms, total 303ms
01-28 19:52:51.922: I/dalvikvm-heap(12661): Grow heap (frag case) to 3.865MB for 460816-byte allocation

我读过一些有关 ART vm 的内容,但我认为情况并非如此,因为 logcat 将两个输出显式标记为“dalvikvm”。

我的应用程序在所有测试的设备和模拟器上都运行正常,从 GB 2.3.3 到 JB 4.3,KitKat 是第一个给我带来问题的版本。

也许 KitKat 有不同的 loadLibrary 管理?我应该实现(我不知道如何!)JNI_OnLoad?

有什么想法吗?


编辑

我在装有 KK 4.4.2 的 Nexus 7 上测试了我的应用,并且运行良好。

下面是生成异常的 C 代码:

jobject Java_my_package_NativeAlloc(JNIEnv* env, jlong numBytes) {
    void *ptr = (char*)malloc(numBytes);
    return (*env)->NewDirectByteBuffer(env, ptr, numBytes);
}

下面是调用它的 Java 代码:

public native static ByteBuffer NativeAlloc(int size);

当然有一个问题,因为 Java int size(32 位)变成了 JNI jlong​​ numBytes(64 位),这是我的错。 但为什么这段代码在 4.4.2 模拟器之前都可以正常工作?

最佳答案

您的函数原型(prototype)不正确,导致您的参数以依赖于平台的方式混合,并且请求的大小可能会损坏。

public native static ByteBuffer NativeAlloc(int size);

应对应于

jobject Java_my_package_NativeAlloc(JNIEnv* env, jclass someClass, jint numBytes)

通过省略 jclass 参数,您可能会损坏其他参数。

这可能在某些平台上平衡了代码中的 jint/jlong​​ 错误,但在其他平台上则不然。

关于Android KitKat 模拟器 native 库 JNI 错误(应用程序错误),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21451696/

相关文章:

android - 在模拟器中看不到应用程序(带有 android 的 netbeans)

Android 添加 native 支持 - Unresolved jni.h、android/log.h 等

java - Android NDK、JNI、蓝牙 : Designing the Android Application which is having C++ source code/library with Bluetooth APIs/methods , 使用 JNI

android-ndk - Android Studio 1.4,实验性插件,JNI 文件夹的路径?

android - jetpack compose 中下拉菜单的默认值

java - 我需要一个可以通过滑动来更改的图标列表,这样整个内容就会改变

java - 在 Ionic Framework 应用程序中调试 Java 插件

android - 如何增加 Android Emulator 的存储空间? (INSTALL_FAILED_INSUFFICIENT_STORAGE)

android - 每次都使用相同的android模拟器

android - 为什么 Android 模拟器/布局编辑器与 iOS 模拟器/ Storyboard相比太慢?