GDB调试技巧
1. 查看内存分布 (gdb) info proc mappings
2. 对于类的调试,先通过行号来设断点, 比如:(gdb) b TcpConnection.cc:63
3. 打印数组的内容 (gdb) p *array@len
4. 查看全局变量的地址,比如info line <variable>
5. 使用十六进制逐个打印内存 x/10xb <address>,其中第二个x是16进制,b是字节
6. 通过指针打印对象 p *(<class> *)<address>
7. 使用up和down切换堆栈,查看堆栈内的locals,如p <variable>
7. 举例如何看汇编和寄存器,下面r开头的寄存器表示64位寄存器
这是一个string的compare函数
(gdb) disassemble 0x00007fb12eeff2ac <- 根据指令地址获得汇编代码
0x00007fb12eeff2a0 <+0>: push %rbp
0x00007fb12eeff2a1 <+1>: push %rbx
0x00007fb12eeff2a2 <+2>: sub $0x8,%rsp
0x00007fb12eeff2a6 <+6>: mov (%rdi),%rdi <- 第一个参数是this指针,取得的是string的M_data
0x00007fb12eeff2a9 <+9>: mov (%rsi),%rsi <- 第二个参数是对比的字符串,取得的是string的M_data
=> 0x00007fb12eeff2ac <+12>: mov -0x18(%rdi),%rbp <- 取第一个字符串的size, 地址是偏移24Bytes,第三个整型
0x00007fb12eeff2b0 <+16>: mov -0x18(%rsi),%rbx
0x00007fb12eeff2b4 <+20>: mov %rbp,%rdx <- 以下三句是取%rbp 和 %rbx的min值,最终min的结果存在%rdx
0x00007fb12eeff2b7 <+23>: cmp %rbp,%rbx
0x00007fb12eeff2ba <+26>: cmovbe %rbx,%rdx
0x00007fb12eeff2be <+30>: callq 0x7fb12ee9ec70 <memcmp@plt> <- %rdi, %rsi, %rdx 构成了memcmp的三个参数
0x00007fb12eeff2c3 <+35>: test %eax,%eax
std::string::compare代码如下
int
compare(const basic_string& __str) const
{
const size_type __size = this->size();
const size_type __osize = __str.size();
const size_type __len = std::min(__size, __osize);
int __r = traits_type::compare(_M_data(), __str.data(), __len);
if (!__r)
__r = _S_compare(__size, __osize);
return __r;
}
通过info registers可以获得上述的%rdi, %rsi, %rdx寄存器的值
通过x/147cb打印147Byte的字符串
通过x/1xg打印一个64位的整型
GDB调试技巧的更多相关文章
- GDB调试技巧:总结篇
目录 一 写在开头 1.1 本文内容 二 学习资料 三 常用命令 四 调试技巧 注:原创不易,转载请务必注明原作者和出处,感谢支持! 一 写在开头 1.1 本文内容 总结GDB调试的一些常用命令和调试 ...
- pwn 题GDB调试技巧和exp模板
GDB分析ELF文件常用的调试技巧 gdb常用命令 首先是gbd+文件名 静态调试 ,gdb attach +文件名 动态调试 为了方便查看堆栈和寄存器 最好是安装peda插件 安装 可以通过pip直 ...
- gdb调试技巧 找到php执行进程当前执行的代码
假设线上有一段php脚本,突然在某天出问题了,不处理但是进程没有退出.这种情况可能是异常休眠或者是有段死循环代码,但是我们怎么定位呢,我们这个时候最想知道的应该是这个脚本在此刻在做什么吧.这个是gdb ...
- 100个gdb调试技巧
找到的一个有参考价值的关于GDB调试的站点:https://gitlore.com/subject/15
- GDB 调试技巧(不断更新中......)
一.break到不同类的同名函数 方法: 在函数前面加类名以及作用域运算符 eg : break A::func //break 到类A的func函数 程序如下: //gdb_test.cpp #in ...
- Linux基础 30分钟GDB调试快速突破
引言 Linus心灵鸡汤 在*nix开发中有道卡叫gdb调试,不管你怎么搞. 它依然在那丝毫不会松动.今天致敬一个 活着的传奇 Linus Torvalds Unix 始于上个世纪60年代,在70年代 ...
- GDB调试基础
GDB调试基础 https://lesca.me/archives/gdb-basic-knowledge.html GDB笔记(二):条件断点.命令列表.监视点 https://lesca.me/a ...
- GDB调试命令手册
使用GDB 启动 $ gdb program # program是你的可执行文件,一般在当前目录 $ gdb program core # gdb同时调试运行程序和cor ...
- 【转贴】gdb中的信号(signal)相关调试技巧
一篇不错的帖子,讲的是gdb中的信号(signal)相关调试技巧 转自Magic C++论坛 http://www.magicunix.com/index_ch.html http://www.m ...
随机推荐
- rel=nofollow 是什么意思
nofollow是什么意思? nofollow是html标签的一个属性值,Google推荐使用nofollow,告诉机器(爬虫)无需追踪目标页,是指禁止蜘蛛爬行和传递权重,但是如果你是通过sitema ...
- 不让input表单的输入框保存用户输入的历史记录
如何不让input表单的输入框保存用户输入的历史记录. 有时我们在设计网页时不想让表单保存用户输入历史记录,比如一些隐私数据,或一些冲值卡 <input name="test&quo ...
- Zephyr-MQTT
Zephyr OS 支持MQTT协议,其源码目录在: # cd /zephyr-/samples/net/paho_mqtt_clients/publisher/ # cd /zephyr-1.5.0 ...
- ios开发学习--歌词处理--解析lrc文件
我觉得要想解析lrc 首先大家应该了解一下lrc文件的结构,大家可以去看一下**百科 我这里粗略的写一下: ■ 时间标签(Time-tag) 形式为"[mm:ss]"(分钟数:秒数 ...
- FileUtils
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...
- Python4Delphi也是与VCL密切相关,所以才能相互调用,绝对有研究价值!
Python4Delphi也是与VCL密切相关,所以才能相互调用,绝对有研究价值! http://www.cnblogs.com/GarfieldTom/archive/2013/01/17/2864 ...
- c++ smart pointer
智能指针(smart pointer)是存储指向动态分配(堆)对象指针的类,用于生存期控制,能够确保自动正确的销毁动态分配的对象,防止内存泄露.它的一种通用实现技术是使用引用计数(reference ...
- VS2012中使用编译的Qt-5.1.1静态库开发程序
1. 安装qt-vs-addin-1.2.2-opensource.exe,安装之后,vs2012菜单栏就会出现QT5菜单. 2. 在qt-vs-addin添加Qt5静态库: QT5->Qt O ...
- BAT 批处理实现循环备份N天文件夹
@echo off set today=%date:~0,4%%date:~5,2%%date:~8,2% xcopy /E /I E:\aaa e:\test\%today% for /f &qu ...
- mysql 安装补充
1:假如下载的文件名为:mysql-5.0.45.tar.gz 2:假如copy到 /usr/local下 3:groupadd mysql #添加mysql组 4:useradd -g mysql ...