15

我正在尝试使用本机代码构建 android 应用程序,所以我想测试 ndk 是否成功运行。当我尝试运行我的第一个 hello world 项目时,日志猫说,

01-21 23:30:06.780: E/AndroidRuntime(939): FATAL EXCEPTION: main
01-21 23:30:06.780: E/AndroidRuntime(939): java.lang.UnsatisfiedLinkError: 
Native method not found: com.example.ndktesting.MainActivity.invokeNativeFunction:()Ljava/lang/String;

我检查了一些 stackoverflow 答案,但找不到我的答案。这是我的 java 代码,我使用的是 android ndk r8d 版本。

//ndktest.c

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

extern "C"{
    JNIEXPORT jstring JNICALL   Java_com_example_ndktesting_ndktest_MainActivity_invokeNativeFunction(JNIEnv* env, jobject  thiz)
};

JNIEXPORT jstring JNICALL   Java_com_example_ndktesting_ndktest_MainActivity_invokeNativeFunction(JNIEnv* env, jobject  thiz){
    return (*env)->NewStringUTF(env, "Hello from native code!");
}

这是我的 MainActivity java 代码:

package com.example.ndktesting;

public class MainActivity extends Activity {    
    //declare the native code function - must match ndktest.c
    private native String invokeNativeFunction();

    public native String  unimplementedinvokeNativeFunction();

    // load the library - name matches jni/Android.mk 
    static {
        System.loadLibrary("ndktest");
    }

    @Override
    protected void onCreate(Bundle savedInstanceState){
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // this is where we call the native code
        String hello = invokeNativeFunction();

        new AlertDialog.Builder(this).setMessage(hello).show();
    }
}

Android制作文件代码:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

# Here we give our module name and source file(s)
LOCAL_MODULE    := ndktest
LOCAL_SRC_FILES := ndktest.c

include $(BUILD_SHARED_LIBRARY)
4

1 回答 1

35

您的包/类名称不匹配。

JNIEXPORT jstring JNICALL   Java_com_example_ndktesting_ndktest_MainActivity_invokeNativeFunction(JNIEnv* env, jobject  thiz)

将是类中的一个方法

com.example.ndktesting.ndktest.MainActivity

但是您的实际代码

package com.example.ndktesting;

public class MainActivity extends Activity 

导致它寻找

com.example.ndktesting.MainActivity.invokeNativeFunction

没有“ndktest”

一旦你使名称匹配,它应该可以工作,或者暴露下一个问题。

于 2013-01-21T18:29:11.200 回答