运行环境:windows/android-ndk-r16b
结论说在前面:文件路径太深,怀疑是Android.mk文件里面字符串变量长度有字节数限制
ndk旧编译系统(Android.mk)开发中经常遇到很奇怪的问题,今天我碰到的问题就是完全摸不着头脑,以致于我最终开始怀疑自我了。
问题是这样的:
error: unable to open output file 'D:/xxxxx/projectName/build/intermediates/ndkBuild/debug/obj/local/arm64-v8a/objs-debug/CameraDemo/D_/xxxxx/projectName/src/main/jni/JNICamera.o': 'No such file or directory'
1 error generated.
中间"xxxxx"代表的是一串比较长的文件路径,报错的路径很奇怪,是我完全不认识的路径,而且报的是中间文件找不到。完全不知道应该怎么分析这个问题。
经过我多次尝试,排除了n+1种可能后,我开始怀疑是我的项目路径太深导致,而且伴随着分析的深入这个怀疑越来越能站的住脚。
最终实锤文件路径太深的方法很简单:
1. 我把项目深度减少到一定层级后已经可以正常编译。
2. 在第一步正常编译成功后,不改变项目深度的前提下我把项目根目录名字改成了一个巨长的,结果果然就复现了这个问题