![](/img/trans.png)
[英]Integrating an external pure Java library and having Android classes access on it
[英]Android external library access
我正在尝试从我正在处理的 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'
}
你的 Java 类应该声明一个本地方法,例如
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");
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.