Android JNI java.lang.UnsatisfiedLinkError

时间:2013-03-15 18:02:09

标签: android android-ndk java-native-interface

我正在尝试实现another question处找到的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)

Everything编译成功(ndk-build和Eclipse项目),但是当我调用Utils.rotateBitmapCcw90传递Bitmap时,我得到一个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中,但是出现了同样的错误。

4 个答案:

答案 0 :(得分:1)

我将lib名称从utils更改为bitmaputils后终于开始工作了。

答案 1 :(得分:0)

尝试这样做:

import android.graphics.Bitmap;

static {
        System.loadLibrary("utils");
    }

public class Utils {


    public static native Bitmap rotateBitmapCcw90(Bitmap bitmap);
}

答案 2 :(得分:0)

您的ndk代码位于“com_test_jnitest_Utils.cpp”中, 但是在“Android.mk”中添加“com_test_jnitest_Utils.c”。 如果更改文件扩展名,则此程序中没有错误。

答案 3 :(得分:0)

.mk文件中的

应该是这样的:

LOCAL_MODULE    := utils