Android NDK开发遇到的问题总结

本文总结了Android NDK开发中遇到的几个典型问题及解决方法,包括编译SO文件报错、执行ndk-build命令失败、JNI方法调用异常以及UART串口通信异常。通过修改Gradle配置,如设置android.useDeprecatedNdk=true,调整abiFilters,以及修正so文件路径,可以解决这些问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、编译成so文件时报错问题:
Error:Execution failed for task ':app:compileDebugNdk'.
> Error: Your project contains C++ files but it is not using a supported native build system.
  Consider using CMake or ndk-build integration with the stable Android Gradle plugin:
   https://developer.android.com/studio/projects/add-native-code.html
  or use the experimental plugin:
   https://developer.android.com/studio/build/experimental-plugin.html.
解决办法:
在项目的gradle.properties添加android.useDeprecatedNdk=true
在module的build.gradle(Module:app)的buildTypes上面添加sourceSets属性
 sourceSets {
        main {
            jni.srcDirs = ['src/main/jni', 'src/main/jni/']
            jniLibs.srcDirs 'src/main/libs'
        }
    }


最后运行gradle脚本更新build,在编译module即可。
这个问题主要是因为Android studio以前使用ndkCompile后来废弃掉了,Android-Terminal-Emulator没有最近没有更新的缘故。具体的编译最新的NDK编译方式可以看官网
https://developer.android.com/studio/projects/add-native-code.html


2、Error:Execution failed for task ':app:compileDebugNdk'.
> com.android.ide.common.process.ProcessException: Error while executing process D:\installTools\sdk\ndk-bundle\ndk-build.cmd with arguments {NDK_PROJECT_PATH=null APP_BUILD_SCRIPT=D:\tool\ReadUSB1\ReadUSB\app\build\intermediates\ndk\debug\Android.mk APP_PLATFORM=android-25 NDK_OUT=D:\tool\ReadUSB1\ReadUSB\app\build\intermediates\ndk\debug\obj NDK_LIBS_OUT=D:\tool\ReadUSB1\ReadUSB\app\build\intermediates\ndk\debug\lib APP_STL=stlport_shared APP_ABI=armeabi-v7a,armeabi,x86}
解决办法:修改build.gradle文件
android {
    compileSdkVersion 26
    buildToolsVersion '26.0.1'
    defaultConfig {
        applicationId "com.android.read"
        minSdkVersion 25
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        ndk{
            moduleName "serialPort"       //生成的so名字
            cFlags "-DANDROID_NDK -D_RELEASE"
            ldLibs "m","log","jnigraphics"// LOCAL LDLIB
            abiFilters "armeabi-v7a","armeabi","x86"//输出指定三种abi体系结构下的so库
            stl "stlport_shared"//app stl
        }
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    sourceSets {
        main{
            jni.srcDirs = ['src/main/jni','src/main/jni/']
        }
    }
}




3、调用JNI(NDK)方法时报错:
1-21 09:08:52.894 13556-13556/com.android.read E/AndroidRuntime: FATAL EXCEPTION: main
                                                                          Process: com.android.read, PID: 13556
                                                                          java.lang.UnsatisfiedLinkError: No implementation found for java.io.FileDescriptor com.android.read.serialPort.SerialPort.open(java.lang.String, int, int) (tried Java_com_android_read_serialPort_SerialPort_open and Java_com_android_read_serialPort_SerialPort_open__Ljava_lang_String_2II)
                                                                              at com.android.read.serialPort.SerialPort.open(Native Method)
                                                                              at com.android.read.serialPort.SerialPort.<init>(SerialPort.java:61)
                                                                              at com.android.read.MyApplication.getSerialPort(MyApplication.java:37)
                                                                              at com.android.read.uart.SerialPortActivity.onCreate(SerialPortActivity.java:70)
                                                                              at com.android.read.uart.SerialDemoActivity.onCreate(SerialDemoActivity.java:22)
                                                                              at android.app.Activity.performCreate(Activity.java:6222)
                                                                              at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
                                                                              at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2295)
                                                                              at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2407)
                                                                              at android.app.ActivityThread.access$800(ActivityThread.java:151)
                                                                              at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1319)
                                                                              at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                              at android.os.Looper.loop(Looper.java:135)
                                                                              at android.app.ActivityThread.main(ActivityThread.java:5280)
                                                                              at java.lang.reflect.Method.invoke(Native Method)
                                                                              at java.lang.reflect.Method.invoke(Method.java:372)
                                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:963)
                                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:758)


问题原因:so文件缺失报的错误,原来配置的abiFilters属性值只有 "armeabi", "armeabi-v7a", "x86"
解决办法:修改build.gradle文件
ndk{
            moduleName "serialPort"       //生成的so名字
            cFlags "-DANDROID_NDK -D_RELEASE"
            ldLibs "m","log","jnigraphics"// LOCAL LDLIB
            abiFilters "arm64-v8a", "armeabi", "armeabi-v7a", "mips", "x86"//输出指定的几种abi体系结构下的so库
            stl "stlport_shared"//app stl
        }


4、进行UART串口通信时,点击接收数据时出现异常:
01-10 08:28:17.246  1709  1709 E AndroidRuntime: FATAL EXCEPTION: main
01-10 08:28:17.246  1709  1709 E AndroidRuntime: Process: com.android.read, PID: 1709
01-10 08:28:17.246  1709  1709 E AndroidRuntime: java.lang.UnsatisfiedLinkError: dlopen failed: "/data/app/com.android.read-1/lib/arm64/libserialPort.so" has unexpected e_version: 65725
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at java.lang.Runtime.loadLibrary0(Runtime.java:989)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at java.lang.System.loadLibrary(System.java:1562)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at com.android.read.serialPort.SerialPort.<clinit>(SerialPort.java:112)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at com.android.read.MyApplication.getSerialPort(MyApplication.java:37)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at com.android.read.uart.SerialPortActivity.onCreate(SerialPortActivity.java:92)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.app.Activity.performCreate(Activity.java:6709)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2619)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2727)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.app.ActivityThread.-wrap12(ActivityThread.java)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1478)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.os.Looper.loop(Looper.java:154)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:6121)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:905)
01-10 08:28:17.246  1709  1709 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:795)
01-10 08:28:17.249   465  1017 W ActivityManager:   Force finishing activity com.android.read/.uart.SerialDemoActivity
01-10 08:28:17.253   465  1017 W ActivityManager:   Force finishing activity com.android.read/.uart.UartActivity
01-10 08:28:17.307   465  1397 I OpenGLRenderer: Initialized EGL, version 1.4
问题原因:so文件问题,so文件必须与打包时选的模式一志。
解决办法: 如打成debug签名包时,so文件改成app\build\intermediates\ndk\debug\lib\下的so文件.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值