执行程序出现:bash: ./xxx : No such file or directory

我是在debian系统(32位)上编译了一个程序文件 (并没有采用交叉编译工具链)

uname -a

Linux Debian 3.10.90-2-686 #7 SMP Fri Oct 9 20:26:23 CST 2015 i686 GNU/Linux

root@# ldd --version
ldd (Debian EGLIBC 2.11.2-10) 2.11.2
root# gcc --version

gcc (Debian 4.3.2-1.1) 4.3.2


然后想放到虚拟机ubuntu上运行(当前肯定是不能运行的,但是会出现什么错误呢)

 uname -a

Linux ls-virtual-machine 4.2.0-42-generic #49~14.04.1-Ubuntu SMP Wed Jun 29 20:22:11 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux

ldd --version

ldd (Ubuntu EGLIBC 2.19-0ubuntu6.14) 2.19

 gcc --version

gcc (Ubuntu 4.8.4-2ubuntu1~14.04.4) 4.8.4

问题来了:

当我执行时出现如下错误:bash: ./xxx : No such file or directory(xxx为我程序名)

奇怪了,怎么会提示找不到程序文件呢,这给了我们一个学习的机会。

这就需要了解程序执行的过程,程序执行前首先需要加载所需要的动态库,,当一个 需要动态链接 的应用被操作系统加载时,系统必须要 定位 然后 加载它所需要的所有动态库文件。 在Linux环境下,这项工作是由ld-linux.so.2来负责完成的,我们可以通过 ldd 命令来查看一个 应用需要哪些依赖的动态库: 

        linux-gate.so.1 =>  (0xb776b000)
        libpthread.so.0 => /lib/i686/cmov/libpthread.so.0 (0xb774c000)
        libc.so.6 => /lib/i686/cmov/libc.so.6 (0xb7606000)

        /lib/ld-linux.so.2 (0xb776c000)


readelf -l xxx:

Elf file type is EXEC (Executable file)
Entry point 0x8049580
There are 7 program headers, starting at offset 52

Program Headers:
  Type           Offset   VirtAddr   PhysAddr   FileSiz MemSiz  Flg Align
  PHDR           0x000034 0x08048034 0x08048034 0x000e0 0x000e0 R E 0x4
  INTERP         0x000114 0x08048114 0x08048114 0x00013 0x00013 R   0x1
      [Requesting program interpreter: /lib/ld-linux.so.2]
  LOAD           0x000000 0x08048000 0x08048000 0x0b684 0x0b684 R E 0x1000
  LOAD           0x00b684 0x08054684 0x08054684 0x006ac 0x02288 RW  0x1000
  DYNAMIC        0x00b698 0x08054698 0x08054698 0x000d8 0x000d8 RW  0x4
  NOTE           0x000128 0x08048128 0x08048128 0x00020 0x00020 R   0x4
  GNU_STACK      0x000000 0x00000000 0x00000000 0x00000 0x00000 RW  0x4

程序启动时,就需要把ld-linux.so.2加载器将所有的动态库加载后然后再将控制权交给程序的入口。

关于动态库的工作原理,参考:https://blog.csdn.net/hudaliquan/article/details/50055493

在Ubuntu下是找不到/lib/ld-linux.so.2,于是我就从debian的lib中把ld-linux.so.2拷贝到ubuntu中(由于ld-linux.so.2是一个软连接,实际

拷贝的文件是ld-2.11.2.so,然后再ubuntu中手动建立ld-2.11.2.so软连接)

然后再执行程序,好的,没有再报bash: ./xxx : No such file or directory错误了,看似有点效果,然而也只是有一点效果而已,

程序还是无法执行的。

程序执行会报错 bash:.xxx Permission deny. 详细原因由于时间关系留以后研究。

你可能感兴趣的:(执行程序出现:bash: ./xxx : No such file or directory)