【问题标题】:Android JNI java.lang.UnsatisfiedLinkErrorAndroid JNI java.lang.UnsatisfiedLinkError
【发布时间】:2013-03-04 13:41:11
【问题描述】:

我正在尝试实现在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)

一切都成功编译(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 中,但出现了相同的错误。

【问题讨论】:

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


    【解决方案1】:

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

    【讨论】:

    • 你的进程已经加载了 libutils.so(来自 /system/lib)
    【解决方案2】:

    尝试这样做:

    import android.graphics.Bitmap;
    
    static {
            System.loadLibrary("utils");
        }
    
    public class Utils {
    
    
        public static native Bitmap rotateBitmapCcw90(Bitmap bitmap);
    }
    

    【讨论】:

    • 对不起,这不能编译
    【解决方案3】:

    您的 ndk 代码在“com_test_jnitest_Utils.cpp”中, 但是您在“Android.mk”中添加了“com_test_jnitest_Utils.c”。 如果更改文件扩展名,此程序不会出错。

    【讨论】:

      【解决方案4】:

      在您的.mk 文件中应该是这样的:

      LOCAL_MODULE    := utils
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2014-10-26
        • 1970-01-01
        • 2014-05-14
        • 1970-01-01
        • 2014-08-25
        • 1970-01-01
        相关资源
        最近更新 更多