【Linux之·readelf工具·二进制程序处理工具】

2024-06-06 10:52

本文主要是介绍【Linux之·readelf工具·二进制程序处理工具】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

系列文章目录


文章目录

  • 前言
  • 一、使用readelf工具查看程序代码变量的内存空间布局情况
    • 1.1 源程序与程序的映射
    • 1.2 程序到进程的映射
  • 二、readelf指令
    • 2.1 节头信息
    • 2.2符号表段中的项
  • 总结


前言

  在现代软件开发中,了解和理解可执行文件和共享库的结构变得越来越重要。而readelf工具正是一个强大的工具,它能够帮助开发人员深入了解和分析可执行文件和共享库的结构和内容。通过readelf工具,我们可以获取有关文件的一些重要信息,如符号表、节区、动态链接等等。我们将从基础知识开始,介绍readelf工具的原理和功能。从而使读者能够更好地理解和分析可执行文件和共享库。无论是在调试、优化代码性能还是进行漏洞分析,掌握readelf工具都将为我们提供强大的工具和洞察力。


一、使用readelf工具查看程序代码变量的内存空间布局情况

1.1 源程序与程序的映射

描述
BSS段存放未初始化的全局变量或静态变量,Block Started by Symbol
DATA段存放已初始化的变量
TEXT段存放二进制代码

1.2 程序到进程的映射

描述
程序代码区存放函数体二进制代码
常量区存放常量、字符串等,只读
全局数据区存放全局变量、静态变量等,可读可写
堆区存放进程运行中被动态分配的内存段,可动态扩展或缩减
动态链接库用于在程序运行期间加载和卸载动态链接库
栈区存放函数的参数值局部变量的值等
#include<stdio.h>int v1;
int v2 = 0;
static int v3;
static int v4 = 4;int main(void)
{int v5;return 0;
}

v1、v2、v3都是未初始化的全局变量,所以在BSS段
v4为已初始化的全局变量,所以在DATA段
v5位局部变量,存储在栈(stack) 中。

注意: 未初始化的全局变量和静态变量以及被初始化为0的全局和静态变量

二、readelf指令

在Linux中,可以使用readelf指令来查看相应的信息。ELF(The Executable and Linking Format),是Linux的主要可执行文件格式,包含三种:

  • 可执行文件(.out)
  • 可重定位文件(.o)
  • 共享目标文件(.so)

readelf指令参数说明表:

指令描述
readelf -helf header,头文件信息
readelf -lprogram headers,显示程序头 (段头) 信息
readelf -Ssection headers,显示节头信息
readelf -ssymbols,显示符号表段中的项
readelf -rrelocs,显示可重定位段的信息
readelf -ddynamic,显示动态段的信息
readelf -Vversion-info,显示版本段的信息
readelf -Aarch-specific,显示CPU构架信息
readelf -Ihistogram,显示符号的时候,显示bucket list长度的柱状图
readelf -aall 显示全部信息,等价于 -h -l -S -s -r -d -V -A -I

2.1 节头信息

There are 28 section headers, starting at offset 0x1950:节头:[] 名称              类型             地址              偏移量大小              全体大小          旗标   链接   信息   对齐
......[13] .text             PROGBITS         00000000000004f0  000004f00000000000000192  0000000000000000  AX       0     0     16
......[15] .rodata           PROGBITS         0000000000000690  000006900000000000000004  0000000000000004  AM       0     0     4
......[22] .data             PROGBITS         0000000000201000  000010000000000000000014  0000000000000000  WA       0     0     8[23] .bss              NOBITS           0000000000201014  000010140000000000000014  0000000000000000  WA       0     0     4

2.2符号表段中的项

   Num:    Value          Size Type    Bind   Vis      Ndx Name......34: 000000000020101c     4 OBJECT  LOCAL  DEFAULT   23 v335: 0000000000201010     4 OBJECT  LOCAL  DEFAULT   22 v4......51: 0000000000201020     4 OBJECT  GLOBAL DEFAULT   23 v1......64: 0000000000201018     4 OBJECT  GLOBAL DEFAULT   23 v2
#include<stdio.h>int v1;
int v2 = 0;
static int v3;
static int v4 = 4;int main(void)
{int v5;return 0;
}
  • v1: 未初始化变量,是一个GLOBAL符号,地址为0000000000201020,从Section Headers可以看到这个地址位于bss段;
  • v2: 初始化变量为0,是一个GLOBAL符号,地址为0000000000201018,从Section Headers可以看到这个地址位于bss段;
  • v3: 未初始化变量,但是被static修饰,所以为LOCAL,地址为000000000020101c,从Section Headers可以看到这个地址位于bss段;
  • v4: 初始化变量为非0,但是被static修饰,所以为LOCAL,地址为0000000000201010,从Section Headers可以看到这个地址位于data段。

总结

这篇关于【Linux之·readelf工具·二进制程序处理工具】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

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

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Linux安装MySQL的教程

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

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

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

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件