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文件.
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文件.