首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有ndk的本机应用程序不起作用

带有ndk的本机应用程序不起作用
EN

Stack Overflow用户
提问于 2012-06-20 05:30:44
回答 2查看 361关注 0票数 1

我有两个设备。一个是HTC Nexus-One运行2.3.6,另一个是LG Optimus V运行2.2.2。该项目有一个我正在使用android ndk构建的jni库。应用程序在Nexus-One设备上安装和运行没有任何问题,但在LG-设备上崩溃并出现以下错误:

代码语言:javascript
复制
06-19 16:20:57.192: E/AndroidRuntime(3044): FATAL EXCEPTION: main
06-19 16:20:57.192: E/AndroidRuntime(3044): java.lang.ExceptionInInitializerError
06-19 16:20:57.192: E/AndroidRuntime(3044):     at java.lang.Class.newInstanceImpl(Native Method)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at java.lang.Class.newInstance(Class.java:1429)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.os.Handler.dispatchMessage(Handler.java:99)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.os.Looper.loop(Looper.java:123)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at android.app.ActivityThread.main(ActivityThread.java:4627)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at java.lang.reflect.Method.invokeNative(Native Method)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at java.lang.reflect.Method.invoke(Method.java:521)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:893)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:651)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at dalvik.system.NativeStart.main(Native Method)
06-19 16:20:57.192: E/AndroidRuntime(3044): Caused by: java.lang.UnsatisfiedLinkError: Library filters-jni not found
06-19 16:20:57.192: E/AndroidRuntime(3044):     at java.lang.Runtime.loadLibrary(Runtime.java:466)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at java.lang.System.loadLibrary(System.java:557)
06-19 16:20:57.192: E/AndroidRuntime(3044):     at com.test.MainActivity.<clinit>(MainActivity.java:427)
06-19 16:20:57.192: E/AndroidRuntime(3044):     ... 15 more

我的make文件(Android.mk)如下所示:

代码语言:javascript
复制
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

LOCAL_MODULE    := filters-jni
LOCAL_SRC_FILES := filters.c
LOCAL_CFLAGS := -DHAVE_CONFIG_H -DFPM_ARM -ffast-math -O3 -Wall
LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -ldl
# for native audio
LOCAL_LDLIBS    += -lOpenSLES
# for logging
LOCAL_LDLIBS    += -llog
# for native asset manager
LOCAL_LDLIBS    += -landroid
LOCAL_STATIC_LIBRARIES := cpufeatures
include $(BUILD_SHARED_LIBRARY)
$(call import-module,cpufeatures)

而我的应用程序make文件只有一行

代码语言:javascript
复制
    APP_ABI := all

到底是怎么回事,我无法理解。感谢所有人的建议。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-06-20 05:36:06

OpenSLES库仅在Android2.3中可用。

请参阅NDK发行版中的docs/STABLE-APIS.html文件,了解适用于安卓版本的库的列表。

票数 2
EN

Stack Overflow用户

发布于 2012-06-20 05:35:14

将此代码放入Application.mk文件中,看看会发生什么:

代码语言:javascript
复制
APP_ABI := armeabi armeabi-v7a x86

这使设备有三个.so可供选择

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11109747

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档