在Ubuntu系统下进行开发工作,经常用到一些嵌入式的编译器,而会碰到可执行文件存在但是无法执行的情况,从Ubuntu 14.04到Ubuntu 18.04都有出现这种情况,现在把相关的解决方法同大家分享。
可执行文件存在但是不能执行,现象可能有很多种情况,比如下面两种。
1.系统函数调用某个可执行文件,但是这个可执行文件无法执行,然后报错,比如: posix_spawn failed: No such file or directory
2.在bash中直接执行的一个可执行文件,也有文件不存在的提示: clang: error: no such file or directory
这个时候我们可能就会通过ls命令来确定这个文件到底是不是真的存在,当看到ls看到文件存在时,很可能就放松了警惕。出现问题需要仔细辨别问题的root cause,可能有很多表面的报错,一定要弄清楚,到底是执行什么操作的时候程序挂了。
对于可执行文件明明存在,但是无法执行,多数情况下都是在64位系统上,出问题的可执行文件是32位的,比如: # file xxx xxx: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.2, for GNU/Linux 2.2.5, stripped
通过file命令可以看到这个可执行程序的位数,通过ldd可以查看这个可执行文件需要的动态链接库,比如: # ldd xxx linux-gate.so.1 (0xf7f44000) libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xf7d4b000) /lib/ld-linux.so.2 (0xf7f46000)
这个时候,如果这个文件却是存在,但是不能执行,如果文件没有损坏,那很可能就是因为依赖的动态库不存在,一般是这个: /lib/ld-linux.so.2
有这个库才能在64位的系统上执行32位的程序,所以根据你的系统,把这个库安装上即可。所使用的命令是: sudo dpkg --add-architecture i386 sudo apt install libc6:i386 也请参考类似情况的解决32位汇编程序在64位Ubuntu 18.04系统上的汇编和连接一文。
相关主题 |