[英]Android JNI java.lang.UnsatisfiedLinkError
我正在嘗試實現在另一個問題上發現的rotateBitmapCcw90方法。 為了使用此方法,我創建了一個名為Utils的Java類。 這個類很簡單:
package com.test.jnitest;
import android.graphics.Bitmap;
public class Utils {
static {
System.loadLibrary("utils");
}
public static native Bitmap rotateBitmapCcw90(Bitmap bitmap);
}
rotateBitmapCcw90下poject_path / JNI內部com_test_jnitest_Utils.cpp實現。 該文件的內容是:
#include <jni.h>
#include <android/log.h>
#include <android/bitmap.h>
#include <stdio.h>
#include <stdlib.h>
#define LOG_TAG "libutils"
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__)
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__)
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__)
extern "C" {
JNIEXPORT jobject JNICALL Java_com_test_jnitest_Utils_rotateBitmapCcw90(JNIEnv * env, jobject obj, jobject bitmap)
{
// same code of other question
...
}
};
我的Android.mk是:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := libutils
LOCAL_SRC_FILES := com_test_jnitest_Utils.cpp
LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog
LOCAL_LDLIBS += -ljnigraphics
include $(BUILD_SHARED_LIBRARY)
一切都可以成功編譯(ndk-build和Eclipse項目),但是一旦我通過位圖調用Utils.rotateBitmapCcw90,就會得到一個java.lang.UnsatisfiedLinkError。 日志顯示:
03-15 14:46:48.243: D/dalvikvm(1936): Trying to load lib /data/data/com.example.jnitest/lib/libutils.so 0x40f77c98
03-15 14:46:48.253: D/dalvikvm(1936): Added shared lib /data/data/com.example.jnitest/lib/libutils.so 0x40f77c98
03-15 14:46:48.253: D/dalvikvm(1936): No JNI_OnLoad found in /data/data/com.example.jnitest/lib/libutils.so 0x40f77c98, skipping init
03-15 14:46:48.333: W/dalvikvm(1936): No implementation found for native Lcom/test/jnitest/Utils;.rotateBitmapCcw90:(Landroid/graphics/Bitmap;)Landroid/graphics/Bitmap;
問題是:我在做什么錯? 我的cpp文件有問題嗎? 我也已經嘗試使用javah生成標頭並將其包含在我的cpp中,但是出現相同的錯誤。
將lib名稱從utils更改為bitmaputils后,我終於使它起作用。
嘗試這樣做:
import android.graphics.Bitmap;
static {
System.loadLibrary("utils");
}
public class Utils {
public static native Bitmap rotateBitmapCcw90(Bitmap bitmap);
}
您的ndk代碼在“ com_test_jnitest_Utils.cpp”中,但是您在“ Android.mk”中添加了“ com_test_jnitest_Utils.c”。 如果更改文件擴展名,則此程序沒有錯誤。
.mk
文件中的文件應如下所示:
LOCAL_MODULE := utils
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.