答网友问:嵌入式Linux执行程序提示Not found的解答

2024-02-10 02:32

本文主要是介绍答网友问:嵌入式Linux执行程序提示Not found的解答,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

某日,网友不会飞的骆驼问了我一个问题。在嵌入式Linux系统中执行./a.out时,提示找不到,信息如下:

$ ./a.out 
-sh: ./a.out: not found

找了点资料,帮解决了。

问题重现

我在板子上重现了问题。的确如上所述。
使用file命令查看a.out属性,信息如下:

file ./a.out 
./a.out: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux-armhf.so.3, for GNU/Linux 2.6.32, BuildID[sha1]=89b9b01541d4f84bfba73ce649cdd2982bb3840e, stripped

从信息上看,a.out是32位ARM系统程序,动态链接,解析器为/lib/ld-linux-armhf.so.3。但是,在板子上查看该文件:

$ ls /lib/ld-linux*
/lib/ld-linux.so.3

可以看到只有ld-linux.so.3,找不到前面提到的ld-linux-armhf.so.3,所以执行程序时提示not found。
造成这个问题的原因是:板子上的系统所用的链接器版本,与编译程序的交叉编译器的链接器版本不一致。先试试将交叉编译器的链接器拷贝到板子系统中,再次执行:

$ ./a.out 
./a.out: /lib/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by ./a.out)

提示信息变化了,但还是出错,是因为c++库的版本号不对应。即a.out使用的版本是GLIBCXX_3.4.21,但系统上的c++动态库没有这个版本号。在板子上查找这个库,信息如下:

$ ll  /lib/libstdc\+\+.so.6*
lrwxrwxrwx    1 root     root            19 Jan 21  2017 /lib/libstdc++.so.6 -> libstdc++.so.6.0.16
-rwxr-xr-x    1 root     root       1044441 Oct 15 09:57 /lib/libstdc++.so.6.0.16

从中得到,c++库版本为6.0.16(姑且这么认为)。
再在交叉编译器目录中查找,已精简的信息如下:

$ ll ./sysroots/usr/lib/libstdc++*
./sysroots/usr/lib/libstdc++.so -> libstdc++.so.6.0.21*
lrwxrwxrwx 1 latelee latelee      19 Jan 14 08:23 ./sysroots/usr/lib/libstdc++.so.6 -> libstdc++.so.6.0.21*
-rwxr-xr-x 1 latelee latelee 1240644 Jun 20  2018 ./sysroots/usr/lib/libstdc++.so.6.0.21*

可以看到,c++库的版本为6.0.21。这样,更能印证版本不匹配的问题了。

解决办法

确认清楚板子系统使用哪个版本的编译器,再使用这个版本编译程序源码即可。在实践中,u-boot、kernel、busybox以及应用层,必须统一使用一套相同的编译器,否则,会出现各种问题。
(注:也不一定要必须,但是,统一一个版本的话,将减少很多不必要的麻烦)

其它扩展

之前曾经也遇到过此类问题,写在此,作为一个扩展知识点。查看交叉编译器版本,提示信息如下:

latelee@ubuntu:~$ arm-linux-gcc --version
-bash: /home/latelee/bin/gcc-4.6.2-glibc-2.13-linaro-multilib-2011.12/fsl-linaro-toolchain/bin/arm-linux-gcc: No such file or directory

用file命令查看文件属性如下:

/home/latelee/bin/gcc-4.6.2-glibc-2.13-linaro-multilib-2011.12/fsl-linaro-toolchain/bin/arm-fsl-linux-gnueabi-gcc: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.2, for GNU/Linux 2.6.0, stripped

可以看到解析器为/lib/ld-linux.so.2,但这个文件并不存在,所以无法找到。
这个问题很典型,是因为在64位系统中执行32位程序造成的(除交叉编译器外,其它程序亦然)。如何解决?安装32位库即可,命令如下:

sudo apt-get install -y lib32ncurses5 lib32z1

安装完毕后,系统上有/lib/ld-linux.so.2文件。重新执行前面的命令即可显示正常的版本号。

李迟 2019.1.15 中午

这篇关于答网友问:嵌入式Linux执行程序提示Not found的解答的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/695929

相关文章

Linux samba共享慢的原因及解决方案

《Linuxsamba共享慢的原因及解决方案》:本文主要介绍Linuxsamba共享慢的原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux samba共享慢原因及解决问题表现原因解决办法总结Linandroidux samba共享慢原因及解决

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc

springboot报错Invalid bound statement (not found)的解决

《springboot报错Invalidboundstatement(notfound)的解决》本文主要介绍了springboot报错Invalidboundstatement(not... 目录一. 问题描述二.解决问题三. 添加配置项 四.其他的解决方案4.1 Mapper 接口与 XML 文件不匹配

Linux安装MySQL的教程

《Linux安装MySQL的教程》:本文主要介绍Linux安装MySQL的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux安装mysql1.Mysql官网2.我的存放路径3.解压mysql文件到当前目录4.重命名一下5.创建mysql用户组和用户并修

mss32.dll文件丢失怎么办? 电脑提示mss32.dll丢失的多种修复方法

《mss32.dll文件丢失怎么办?电脑提示mss32.dll丢失的多种修复方法》最近,很多电脑用户可能遇到了mss32.dll文件丢失的问题,导致一些应用程序无法正常启动,那么,如何修复这个问题呢... 在电脑常年累月的使用过程中,偶尔会遇到一些问题令人头疼。像是某个程序尝试运行时,系统突然弹出一个错误提

电脑提示找不到openal32.dll文件怎么办? openal32.dll丢失完美修复方法

《电脑提示找不到openal32.dll文件怎么办?openal32.dll丢失完美修复方法》openal32.dll是一种重要的系统文件,当它丢失时,会给我们的电脑带来很大的困扰,很多人都曾经遇到... 在使用电脑过程中,我们常常会遇到一些.dll文件丢失的问题,而openal32.dll的丢失是其中比较

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Linux系统之dns域名解析全过程

《Linux系统之dns域名解析全过程》:本文主要介绍Linux系统之dns域名解析全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、dns域名解析介绍1、DNS核心概念1.1 区域 zone1.2 记录 record二、DNS服务的配置1、正向解析的配置

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓