我正在尝试从我正在处理的Android应用程序中访问Android共享对象。根据有关如何执行此操作的在线信息,我在项目中创建了以下文件夹结构:
|--app:
|--|--src:
|--|--|--main
|--|--|--|--jniLibs
|--|--|--|--|--armeabi
|--|--|--|--|--|--.so Files
|--|--|--|--|--armeabi-v7a
|--|--|--|--|--|--.so Files
在我的java代码中,我试图从共享对象调用的stringFromJNI方法没有被解析。我不知道我需要做些什么才能解决这个问题,因为我已经在线阅读了类似的例子。
以下是应用程序的Java代码:
package com.example.ndktest.androidlibcall;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
public class AndroidLibCall extends AppCompatActivity {
public static String TAG = "AndroidLibCall";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//Log.d(TAG, getRegister());
Log.d(TAG, stringFromJNI);
}
static {
try {
System.loadLibrary("libhello-jni");
}
catch (UnsatisfiedLinkError e)
{
System.out.println("UnsatisfiedLinkError in static block");
e.printStackTrace();
}
}
}
这是我的build.gradle文件:
apply plugin: 'com.android.application'
android {
compileSdkVersion 26
flavorDimensions "versionCode"
defaultConfig {
applicationId "com.example.ndktest.androidlibcall"
minSdkVersion 15
targetSdkVersion 26
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
externalNativeBuild {
cmake {
cppFlags ""
}
}
}
sourceSets {
main {
jniLibs.srcDirs = ['src/main/jnilibs']
}
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
externalNativeBuild {
cmake {
path "CMakeLists.txt"
}
}
productFlavors {
x86 {
ndk {
abiFilter "x86"
}
}
arm {
ndk {
abiFilters "armeabi-v7a", "armeabi"
}
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'com.android.support:appcompat-v7:26.1.0'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
}
如果您需要任何进一步的信息,请与我们联系。
感谢。
答案 0 :(得分:0)
您的Java类应声明 native 方法,例如
private native String stringFromJNI();
现在您可以将其称为您班级的任何其他方法,例如
Log.d(TAG, stringFromJNI() );
不要错过括号!
对于 build.gradle ,当您在 jniLibs 文件夹中提供库时,您不需要externalNativeBuild
。您的productFlavors
部分将因Android Studio 3.0或更高版本而失败,因为您是从过时的示例中选择的。但你可以简单地删除它,因为再次 jniLibs 文件夹将处理这个问题。
未解决的问题是,经过上述更改后,您的 ndktest 是否有效。这取决于您在C ++代码中的内容,以及如何构建文件 liblibhello-jni.so 。
请注意,您的Java代码会查找上面显示的特殊文件。
如果您的预建文件名为 libhello-jni.so ,则必须更改Java:
System.loadLibrary("hello-jni");