Android JNI java.lang.UnsatisfiedLinkError

标签 android android-ndk java-native-interface

我正在尝试实现在 another question 找到的方法 rotateBitmapCcw90 . 为了使用这个方法,我创建了一个 java 类,命名为 Utils。这个类很简单:

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 生成 header 并将其包含在我的 cpp 中,但出现了同样的错误。

最佳答案

在将 lib 名称从 utils 更改为 bitmaputils 后,我终于让它工作了。

关于Android JNI java.lang.UnsatisfiedLinkError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15439228/

相关文章:

java - C++可以调用Java代码吗?

java - PhoneAuthProvider.OnVerificationStateChangedCallbacks 没有被解雇

android - 在android中通过JNI在C代码中打开文件时获取NULL

java - JNI 和 C++ - UnsatisfiedLinkError

java - java中如何保存从jni返回的void*以供以后使用

android-ndk - 如何为 Android 编译 libogg 和 libvorbis

java - JNI UnsatisfiedLinkError 问题

java - android 错误 : java. lang.NullPointerException

java - 如何重新抛出异常

android - AppWidgetProvider:onAppWidgetOptionsChanged 未在小部件放置时调用