各位看官们,大家好。我们在上一回中说简单地介绍了GDB。这一回中,我们介绍GDB的调试功能:单步

调试。

闲话休提,言归正转。

让我们一起talk GDB吧!

看官们,我们先说一下什么是单步调试。大家都知道。程序是依照指令。一步一步地执行,仅仅是程序执行

的非常快,所以你没有办法看到走过的每一步。

这个有点类似我们寻常走路,一步一步地向前走,在路上可

以看到很多风景,假设坐车,那么车速太快了,就会看不清楚路上的风景。单步调试就是不让程序非常快地

执行,通俗点说,说是不让程序“坐车”走,让程序一步一步地执行。

我们来看看怎样使用GDB让程序一步一步地执行。具体的过程例如以下:

  • 1.启动GDB:gdb file.o(表示使用GDB对file.o这个程序进行调试);
  • 2.開始调试:start.这个时候。GDB会从file.o程序中的main函数開始执行;
  • 3.单步调试:next(能够缩写为n)。

    程序执行到下一条语句;

  • 4.重复调试:继续输入n,程序就会跳到下一行。如此重复,程序就会一步步地执行。

这里有个技巧和大家共享一下:运行完第一个n命令后,假设想继续运行n命令,那么仅仅须要按下回车键就

能够继续运行n命令。而不须要继续输入n,由于在GDB中回车键表示反复运行它前面的命令,这个有点类似

Linux中的点命令。

在单步调试过程中遇到程序中的函数时。会把函数调用当做一个总体。大家可能不理解。没关系,咱们举个

样例:程序中有下面三条语句:

a =5;b = 3;

c =min(a,b); //min是求最小值的一个函数

printf("min is :%d",c);

当程序执行到“a =5;b = 3;”这行时。使用单步调试命令n,程序会执行到“c =min(a,b);”这一行,假设再执行

单步调试n。那么程序会执行到“printf("min is :%d",c);“这一行。大家都知道,函数是多个语句组成的,不

会一步就执行完,可是单步调试的时候把函数看成了一个总体,让它一步执行完。

假设我们想看函数中每

个语句的执行步骤,怎么办?看官莫急。强大的GDB不会让我们失望的。我们能够使用GDB的命令:step

(缩写为s),使用该命令能够进入函数中。

然后就能使用单步调试命令。一步一步地看清楚函数中每条语句

的执行步骤了。

假设想从函数中跳出来能够使用命令:finish.这时程序会调用函数的地方,也就是我们样例

中“printf("min is :%d",c);“这一行。

看官们,通过单步调试,我们能够看到程序执行的“脚印”。

在调试过程中,假设看到程序执行步骤与我们

事先给程序设计好的步骤不一样,那么说明程序没有依照我们设计的步骤走。这肯定是有地方出问题了。

我们须要把出问题的地方找出来。由于程序是一步一步地执行,所以我们非常easy找到哪一步出了问题,进

而找出问题的解决办法。这便是单步调试的作用。当然了。单步调试还有其他的作用。它能够和其他调试方法

一起配合使用,至于是什么调试方法。我们以后在的章回中会介绍。

我们平时还认为电脑上的程序不够快呢,你还不让它“坐车”,让它步行。这不让电脑更加慢了吗?看官说的

有道理。只是,我们通过单步调试让程序运行慢下来,目的是为了看清楚程序每一步运行时的样子,这样

有助于我们发现程序中错误。进而方便我们改动程序中错误。试想一下。程序“坐着车”跑的那么快,你还没

有看清楚它的样子。它已经跑的无影无踪,更不要说找它的运行时的错误了。

看官们,关于GDB的内容。今天咱们就讲到这里。

欲知后事怎样,且听下回分解!

一起talk GDB吧(第二回:GDB单步调试)的更多相关文章

  1. GDB:从单线程调试到多线程调试(MFiX单步调试)

    GDB:从单线程调试到多线程调试 1. 裸跑GDB 1.1 安装GDB sudo apt-get install gdb 1.2 编译程序 由于需要调试,因此编译的时候需要添加-g编译参数: 1.3 ...

  2. GDB 单步调试汇编

    本文同时发表在 https://github.com/zhangyachen/zhangyachen.github.io/issues/134 之前在看汇编的时候一直是肉眼看GCC -S的结果,缺点是 ...

  3. 手把手教你使用eclipse+qemu+gdb来单步调试ARM内核【学习笔记】

    平台信息:linux4.0 平台:qemu 作者:庄泽彬 说明:笨叔叔的Linux视频的笔记 一.编译linux源码 export CROSS_COMPILE=arm-linux-gnueabi- e ...

  4. LINUX上使用GDB单步调试Chromium Android C++代码。

    ###动机###在LINUX使用GDB单步调试Chromium Android C++代码. [1]编译android平台Chromium, 修改GN文件中编译选项:-g -O0 使得编译优化更少,便 ...

  5. GDB调试指南-单步调试

    前言 前面通过<启动调试>,<断点设置>,<变量查看>,我们已经了解了GDB基本的启动,设置断点,查看变量等,如果这些内容你还不知道,建议先回顾一下前面的内容.在启 ...

  6. gdb常用命令及gdb调试多进程/线程程序&coredump

    一.常用普通调试命令 1.简单介绍GDB 介绍: gdb是Linux环境下的代码调试⼯具.使⽤:需要在源代码⽣成的时候加上 -g 选项.开始使⽤: gdb binFile退出: ctrl + d 或 ...

  7. [转]Building a Basic Fuzzer with GDB: The Five Minute GDB Scripting Tutorial

    link:http://www.praetorian.com/blog/building-a-basic-fuzzer-with-gdb-the-five-minute-gdb-scripting-t ...

  8. [gdb][python][libpython] 使用gdb调试python脚本

    https://devguide.python.org/gdb/ https://sourceware.org/gdb/current/onlinedocs/gdb/Python.html#Pytho ...

  9. GDB(十)--调试正在运行的进程

    我编写了一个循环: long i;    for (i = 0; i < 999999; i++) {        mt.a += 1;        sleep(1);    }把它编译成a ...

随机推荐

  1. Codeforces 899B Months and Years

    题目大意 给定 $n$($1\le n\le 24$)个正整数 $a_1,\dots, a_n$ 判断 $a_1$ 到 $a_n$ 是否可能为连续 $n$ 个月份的天数. 解法 由于 $n\le 24 ...

  2. 【CCF】最优灌溉 最小生成树

    [AC] #include<iostream> #include<cstdio> #include<string> #include<cstring> ...

  3. 爬虫【自动登陆github和抽屉】

    自动登陆github用户详情页 代码 #! /usr/bin/env python # -*- coding: utf- -*- # __author__ = "wuxiaoyu" ...

  4. bzoj 2330 [SCOI2011]糖果 差分约束模板

    题目大意 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的多,于是在分配 ...

  5. hdu 4305 生成树计数问题

    Lightning Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  6. 线段树懒标记好题 HDU4578

    (1)"1 x y c",代表 把区间 [x,y] 上的值全部加c (2)"2 x y c",代表 把区间 [x,y] 上的值全部乘以c (3)"3 ...

  7. Windows server 2008 R2 + IIS7.5,ASP网站设置

    Windows server 2008 R2 + IIS7.5,ASP网站设置 1. 让IIS7支持ASP Win2008 IIS7 默认不安装ASP,如果需要ASP 的支持,需要将这个角色服务选上. ...

  8. SpringBoot之ApplicationContextInitializer的理解和使用

    一. ApplicationContextInitializer 介绍 首先看spring官网的介绍: 翻译一下: 用于在spring容器刷新之前初始化Spring ConfigurableAppli ...

  9. php validator classes

    <?php /** * 验证类 */ class Validator { /* 函数名称:isNumber 简要描述:检查输入的是否为数字 输入:string 输出:boolean */ pub ...

  10. Codeforces 620F Xors on Segments(暴力+DP)

    题目链接 Xors on Segments 预处理出$x[i]$ $=$ $1$ $xor$ $2$ $xor$ $3$ $xor$ $……$ $xor$ $i$ 话说这题$O(n^{2})$居然能过 ...