几个命令了解ELF文件的”秘密“
|
副标题[/!--empirenews.page--]
前言 在Linux中,可执行文件的格式是ELF格式,而有一些命令可以帮助我们了解它们更多的“秘密”,以此来帮助我们解决问题。
示例程序 我们的示例程序如下:
编译:
得到hello可执行文件。 查看文件类型 file命令可以用来查看文件类型:
从结果中,我们可以知道,它是ELF可执行文件,且是64位程序,有动态链接,最后的not stripped也表明了它保留了符号表信息或者调试信息。 如果不是可执行文件,它的信息是怎样的呢?举个例子:
看到了吧。 查看ELF头 readelf用于查看ELF文件,而:
可以看到它是EXEC,即可执行文件,且小端程序,运行于X86-64。在交叉编译的时候,这个文件头的信息也非常有用。例如你在x86的机器上交叉编译出powerpc的可执行文件,在powerpc上却不被识别,不能运行,不如用readelf看看它的Machine字段,是不是没有编译好。 查找ELF文件中的字符串 例如,你在文件中写入了版本号或者特殊字符串,可以通过strings命令搜索到:
查看ELF文件各段大小
这里可以看到代码段,数据段各自占多少,必要时候还可以根据需要优化代码,减少磁盘空间占用。 查看链接的动态库 运行时出现找不到动态库?不如看看它链接了哪些库吧:
可以看到它链接的动态库是/lib/x86_64-linux-gnu/libc.so.6,而如果该文件不存在,则运行时将会出错。这里也可以参考《动态库的制作和使用》。 查看符号表 (编辑:伊春站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- windows-server-2008 – 您是否必须运行远程桌面才能访问终
- server-message-block – 如何检查工作站在Windows上使用的
- 微软突然宣传 Windows 1.0,神秘预告吊足胃口
- 微软没强迫? Windows 10 版本号追踪网站 Buildfeed 关闭
- Windows 11等版本集体中招 微软证实存有高危漏洞
- 详解EFK搭建过程及ES的生命周期管理
- Windows Server与常规Windows有何不同?
- windows-server-2008 – 数字字符串类型的AD自定义属性在更
- windows-server-2008 – 在Windows Server中添加子域DNS记录
- 自动更新 – 服务器2016 – 更新重新启动

