我正在尝试在Android Studio中制作helloy-jni应用程序,我有异常
06-27 13:17:19.099 12714-12714/com.example.testjni2 E/AndroidRuntime: FATAL EXCEPTION: main
java.lang.ExceptionInInitializerError
at java.lang.Class.newInstanceImpl(Native Method)
at java.lang.Class.newInstance(Class.java:1319)
at android.app.Instrumentation.newActivity(Instrumentation.java:1071)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2166)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2299)
at android.app.ActivityThread.access$700(ActivityThread.java:154)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1284)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5306)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.UnsatisfiedLinkError: Couldn't load hello-jni from loader dalvik.system.PathClassLoader[dexPath=/data/app/com.example.testjni2-1.apk,libraryPath=/data/app-lib/com.example.testjni2-1]: findLibrary returned null
at java.lang.Runtime.loadLibrary(Runtime.java:365)
at java.lang.System.loadLibrary(System.java:535)
at com.example.testjni2.MainActivity.<clinit>(MainActivity.java:9)
... 15 more
我的结构项目看起来像这样
我添加了build.gradle行:
compile files('libs/armeabi/libhello-jni.so')
但这没有帮助。 我看了Gradle和Android Gradle plugin,但是我找不到有关使用jni文件夹的信息
我正在考虑它是什么file dependencies,但它不起作用
我的hello-jni.c文件包括
jstring Java_com_example_testjni2_MainActivity_stringFromJNI (JNIEnv *env, jobject thiz){
return (*env)->NewStringUTF(env, "Hello from JNI !");
}
我的MainActivity文件包含
public class MainActivity extends Activity {
static {
System.loadLibrary("hello-jni");
}
public native String stringFromJNI();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
String text = stringFromJNI();
Log.i("MainActivity", text);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
我的Android.mk文件包含
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := hello-jni
LOCAL_SRC_FILES := hello-jni.c
include $(BUILD_SHARED_LIBRARY)
请告诉我,我可能会犯错误。
Android Studio 0.1.7 操作系统 - Windows 7 x64
答案 0 :(得分:69)
现在有一种比接受的答案更简单的方法。
您所要做的就是在 / src / main 目录下创建一个名为“jniLibs”的文件夹(即/ app / src / main / jniLibs),把你的.so文件放在那里。它看起来像这样:
app
|
src
|
main
|
jniLibs
|
armeabi
| |
| your_lib_compiled_for_armeabi.so
|
armeabi-v7a
| |
| your_lib_compiled_for_v7a.so
|
x86
| |
| your_lib_compiled_for_x86.so
你的.so文件现在应该被拿起来。
答案 1 :(得分:16)
还有其他方法可以导入到android项目中。
答案 2 :(得分:10)
将此添加到build.gradle:
sourceSets {
main {
jniLibs.srcDir 'jniLibs'
}
}
下面:
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
答案 3 :(得分:8)
gradle构建系统目前不支持捆绑本机库。检查https://groups.google.com/d/msg/adt-dev/nQobKd2Gl_8/Z5yWAvCh4h4J,了解您需要添加到build.gradle的一些自定义任务。
请注意,这是一个临时解决方法,直到gradle支持构建本机项目。
答案 4 :(得分:1)
在gradle 0.7.3上使用* .so文件有一种新方法 请查看此链接How to change libs directory in Gradle?
答案 5 :(得分:0)
对于那些不想手动创建jniLibs
目录的人,这里是放置本机库的官方文档。
官方文件是Android Plugin DSL Reference。查看可在Android Studio中找到的gradle android插件版本。
sourceSets
存储资源信息以编译应用程序。
sourceSets
的{p> jniLibs
用于JNI库。