Linux Binutils 基本使用教程

简介

GNU Binutils(二进制实用程序)是用于在 Unix/Linux 系统中操作二进制文件的工具集合。这些工具有助于汇编、链接、反汇编和检查二进制可执行文件、目标文件、库和汇编代码。

安装

  • Debian/Ubuntu
shell 复制代码
sudo apt update && sudo apt install binutils
  • RHEL/CentOS
shell 复制代码
sudo yum install binutils
  • macOS
shell 复制代码
brew install binutils

常用 Binutils 命令

  • as:GNU 汇编器(将汇编代码转换为机器代码)

  • ld:GNU 链接器(将目标文件链接到可执行文件中)

  • objdump:显示有关二进制文件的信息

  • nm:列出目标文件中的符号

  • ar:创建和管理静态库

  • ranlib:生成静态库的索引

  • strip:从二进制文件中删除调试符号

  • size:显示二进制文件的节大小

  • strings:从二进制文件中提取可读文本

  • readelf:显示有关 ELF(可执行和可链接格式)文件的信息

  • addr2line:将地址转换为源文件和行号

  • c++filt:解密 C++ 符号名称

示例用法

objdump 检查二进制文件

shell 复制代码
objdump -d /bin/ls  # 反汇编 ls 命令
objdump -x /bin/ls  # 显示完整的二进制信息

nm 显示目标文件中的符号

shell 复制代码
nm /bin/ls  # 列出 ls 二进制文件中的符号

strings 提取可读文本

shell 复制代码
strings /bin/ls  # 从二进制文件中提取可读文本

readelf 检查 ELF 文件

shell 复制代码
readelf -h /bin/ls  # 显示 ELF 标头

strip 删除调试符号

shell 复制代码
strip myprogram  # 通过删除符号来减少二进制大小

创建并链接汇编程序

  • 编写一个汇编程序(hello.s)
shell 复制代码
.global _start
.section .text
_start:
    mov $1, %rax
    mov $1, %rdi
    mov $msg, %rsi
    mov $len, %rdx
    syscall

    mov $60, %rax
    xor %rdi, %rdi
    syscall

.section .data
msg: .ascii "Hello, Binutils!\n"
len = . - msg
  • 用 as 组装
shell 复制代码
as hello.s -o hello.o
  • 使用 ld 来链接
shell 复制代码
ld hello.o -o hello
  • 运行程序
shell 复制代码
./hello

输出

shell 复制代码
Hello, Binutils!
相关推荐
心随_风动1 小时前
SUSE Linux 发行版全面解析:从开源先驱到企业级支柱
linux·运维·开源
西北大程序猿2 小时前
单例模式与锁(死锁)
linux·开发语言·c++·单例模式
酷爱码2 小时前
在 Linux 中修改 Apache HTTP Server(httpd)默认端口的完整指南
linux·http·apache
jiunian_cn2 小时前
【Linux】Linux权限
linux·服务器·mysql
betazhou3 小时前
有没有 MariaDB 5.5.56 对应 MySQL CONNECTION_CONTROL 插件
linux·数据库·mysql·oracle·mariadb
烟雨书信3 小时前
Linux中MySQL的逻辑备份与恢复
linux·运维·mysql
wkj0014 小时前
QuaggaJS 配置参数详解
java·linux·服务器·javascript·quaggajs
藥瓿亭4 小时前
K8S认证|CKS题库+答案| 5.日志审计
linux·运维·docker·云原生·容器·kubernetes·cka
coder_lorraine5 小时前
【Linux系列】Linux用户大揭秘:从“公寓住户”到“社区管理员”的奇幻之旅
linux
藥瓿锻5 小时前
2024 CKA题库+详尽解析| 15、备份还原Etcd
linux·运维·数据库·docker·容器·kubernetes·cka