gdb调试技巧(第二篇)

Wesley13
• 阅读 574

在调试的时候,我想知道某个变量、或者某个对象、或者某个结构体的数据类型。如果某个变量 是 foo,怎么做?

ptype foo

当然也可以看某个函数的定义信息。用同样的方法。

如果我想知道某个宏的值,怎么做?需要在编译的时候加上 -g3。加入源代码文件是hello.c

gcc -g3 hello.c

调试 a.out的时候,假如宏的名称是 FOO 就可以这么做了。

info macro FOO

在调试一个循环的时候,你可能想要跳出这个循环。怎么做?

until

u

unt

unti

就会在再次遇到循环之前,跳出循环。

如果想要在gdb中使用终端怎么办?

shell

shel

she

如果只是想执行一个shell命令,比如ls命令,怎么做?

shell ls

如果想要更换被调试的程序。比如决定调试 a2.out 怎么做?

file

file a2.out

如果这个程序需要传入main的运行参数比如是 hello。怎么做?

set args hello

如何知道设置成功了?

show args

如何在程序中看到这个值?给main函数加上断点。然后print args[1]即可。

break main

run

print args[1]

如果想要在gdb 中编辑源代码。怎么做?

edit

edi

ed

如果没有设置默认文本编辑器的环境变量,就会进入vi的 ex模式,想要进入vi的可视化模式?

vi

visual

修改完代码。想要在gdb中直接编译。如果没有 makefile文件的话。怎么做?

shell gcc -g3 hello.c

如果有makefile文件的话。怎么做?

make

对。你可以直接在gdb中执行make命令。这是gdb给make开的一个特权。当然,你完全也可以这么做。

shell make

重新生成可执行程序之后,就得重新导入符号表。怎么做?

file     #释放旧的符合表

file a.out

如果程序运行中,突然异常退出了。检测目录,发现没有生成内存信息文件。怎么做?在shell中执行如下命令。

ulimit -Sc unlimited

检测是否设置成功。

ulimit -Sc

此时,重新运行程序,如果程序再次异常退出。会生出一个 core.进程号 的文件。这是程序在内存中异常退出的时候,记录下来的内存信息。假如进程号是 1000 如何使用它?

gdb core.1000

加载core文件成功之后。

就可以查看core文件中的信息了。

最常用的就是看看程序的栈回溯信息。

backtrace

bt

where

此时,就可以看到栈顶的函数,以及距离栈顶最近的我们自己写的函数。假如我的函数所在的栈位置是3。那么就需要我们跳转的这个栈。以便查看该栈的状况。怎么做?

frame 3

f 3

这样就可以查看该栈(也叫做 帧)的内存信息。比如某个可疑变量的值是否发生越界,等等问题。

一般来说至此,绝大多数的问题可以解决。

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
gdb调试技巧(第一篇)
打算调试某个程序的话,请在编译的时候加上g选项。如果想要在更多的符号信息,比如宏定义的信息,请加g3选项。多个相关选项被将如的话,前面的选项会被后面的覆盖掉。比如源代码是hello.c编译的时候,可以这样。gccghello.c这是最简单的方式。此时会生成一个a.out的可执行程序。想要调试它?这么做
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
Java日期时间API系列23
  有时候,往往需要统计某个时间区间的销量等问题,这就需要准确的起始时间,获取准确开始时间00:00:00,获取准确结束时间23:59:59。下面增加了一一些方法,获取当天起始时间,昨天起始时间,当前月第一天开始时间,当前月最后一天结束时间,上个月第一天开始时间,上个月最后一天结束时间,某个指定月的起始结束时间等等。其中月份最后一天往往因为月份不同和
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这