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 ... 
随机推荐
- DEDE更改版权信息
			DEDECMSV5.7版本出现后,在前台网页底部会出现织梦版权信息 “powered by dedecms”,很多人都不知道怎么去掉 1. 方法一: 在include/dedesql.classs. ... 
- while if 循环判断
			temp=input("猜一下我想的那个数字吧:") guess=int(temp) while guess!=8: temp=input("诶呀错误了在输入一次吧:&q ... 
- 项目知识点.Part3
			内存管理: 基本数据类型或者Core Foundation对象都没有引用计数 主线程会自动创建释放池,子线程需要手动创建释放池. 具体的区别:http://www.cnblogs.com/langti ... 
- Swift-MJ
			1.声明变量 常量 声明变量:var age = 10 声明常量:let age = 10 (不加分号,除非多条语句写在同一行) 二进制前缀:0b(必须小写) 八进制前缀:0o 十六进制前缀:0x 2 ... 
- windows server 2012 iis8.0部署mvc报错
			一开始以为需要在服务器装mvc在很多论坛找过也问了朋友都说需要装mvc,经过两天研究是不需要装mvc的只需要在项目的bin文件夹下放入下面三个dll. 未能加载文件或程序集“System.Web.Ht ... 
- android.support.v7.widget.Toolbar 中menu图标不显示问题
			<?xml version="1.0" encoding="utf-8"?><menu xmlns:android="http:// ... 
- html中混入的特殊字符
			从设计那里拿来的psd中常常会有全角的单双引号. 如果只是拷贝这些字符到做好的html里面,顶多看到乱码再加以改正. 但是,如果是通篇的doc,需要加上各种html语义标签,在拷贝来的doc文字之间加 ... 
- 电容式触摸控制器PCB布局
			在目前市场上可提供的PCB(印刷电路板)基材中,FR4是最常用的一种.FR4是一种玻璃纤维增强型环氧树脂层压板,PCB可以是单层或多层. 在触摸模块的尺寸受限的情况下,使用单层PCB不是总能行得通的, ... 
- Context Switch Definition
			A context switch (also sometimes referred to as a process switch or a task switch) is the switching ... 
- Function语义学之member function
			之前我们讲过编译器会对 nonmember functions 进行怎样的扩充和该写,今天我们来讲一下 member functions 函数调用方式 一.Nonstatic Member Funct ... 
