java.lang.UnsatisfiedLinkError : No implementation found due to Library not loading 错误

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

当它说无法加载 jniLibs 和其他库中的 .so 文件时,我正在尝试将 native 编写的共享库集成到我的应用程序中。

这是C文件

#include <string.h>
#include <jni.h>
#include <dummy.h>

JNIEXPORT jstring
Java_com_example_hellojni_HelloJni_DummyInit(JNIEnv*env, jobject thiz) {

    dummy *handle;
    char *msg;
    int rc = dummy_init_from_id("ml", &handle, &msg);
    if (rc == DUMMY_SUCCESS) {
        return (*env)->NewStringUTF(env, "Init was successful");
    } else {
        return (*env)->NewStringUTF(env, msg);
    }

}

JNIEXPORT void 
Java_com_example_hellojni_HelloJni_DummySetSymbolsDir(JNIEnv *env, jobject thiz,
                                                      jstring dir) {
    dummy_set_symbols_dir(dir);

}

这是Java文件

package com.example.hellojni;

import android.app.Activity;
import android.util.Log;
import android.widget.TextView;
import android.os.Bundle;
import java.io.File;


public class HelloJni extends Activity
{


    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState)
    {

        super.onCreate(savedInstanceState);

        File f = new File(getAssets() + "/ml");
        if (f.exists()) try {

            System.out.println("Scheme exists");
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
        String dir = f.getPath();

        DummySetSymbolsDir(dir);

        TextView tv = new TextView(this);
        tv.setText(DummyInit());
        setContentView(tv);
    }


    /*** Native Methods ***/
    public native String DummyInit();
    public native void DummySetSymbolsDir(String dir);

    static {
        try {
            System.loadLibrary(("dummy"));
        } catch (UnsatisfiedLinkError e) {
            Log.e("JNI", "Warning:Could not use dummy library");
        }
        try {
            System.loadLibrary("libs/libpthead.so");
        } catch (UnsatisfiedLinkError e) {
            Log.e("JNI", "Warning:Could not use lipthread library");
        }
        try {
            System.loadLibrary("hello-jni");
        } catch (UnsatisfiedLinkError e) {
            Log.e("JNI", "Warning:Could not use hello-jni library");
        }
    }
}

具体错误如下

FATAL EXCEPTION: main
Process: com.example.hellojni, PID: 2558
java.lang.UnsatisfiedLinkError: No implementation found for void com.example.hellojni.HelloJni.DummySetSymbolsDir(java.lang.String) (tried Java_com_example_hellojni_HelloJni_DummySetSymbolsDir and Java_com_example_hellojni_HelloJni_DummySetSymbolsDir__Ljava_lang_String_2)
at com.example.hellojni.HelloJni.DummySetSymbolsDir(Native Method)
at com.example.hellojni.HelloJni.onCreate(HelloJni.java:34)
at android.app.Activity.performCreate(Activity.java:6237)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
at android.app.ActivityThread.-wrap11(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

Android.mk文件如下

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE    := hello-jni
LOCAL_SRC_FILES := hello-jni.c
include $(BUILD_SHARED_LIBRARY)

如果需要更多信息,请告诉我。 谢谢。

最佳答案

您可能需要用外部“C” block 包围您的代码:

extern "C" {
    Your JNIEXPORT functions
}

对于 C 和 C++,您可以:

#ifdef __cplusplus
extern "C" {
#endif

    Your JNIEXPORT functions

#ifdef __cplusplus
}
#endif

关于java.lang.UnsatisfiedLinkError : No implementation found due to Library not loading 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38062855/

相关文章:

android - Kotlin-添加更多变体-soundPool

android - iostream : No such file or directory in Android NDK Environment

android - 获取位于android studio for NDK项目中drawable的图像的绝对路径

android studio编辑器错误jni

java - Netty 3 中的channelOpen 和channelClosed 上游事件是否存在一对一的映射?

java - 替换特定 URL 参数中的字符

java - 我的 RSS 阅读器给出了 java.lang.NullPointerException

java - startActivity(intent) 没有做任何事情

java - 用索引迭代 IntStream

android - Build.DEVICE 是否在设备的整个生命周期内保持不变?