Linux第七章之gdb与makefile使用

简介: 3. 如果hello文件不存在,或是hello所依赖的后面的hello.o文件的文件修改时间要比hello这个文件新(可以用touch 测试),那么,他就会执行后面所定义的命令来生成hello这个文件。5. 当然,你的C文件和H文件是存在的啦,于是make会生成 hello.o 文件,然后再用 hello.o 文件声明make的终极任务,也就是执行文件hello了。2. 如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到“hello”这个文件,并把这个文件作为最终的目标文件。

 一、Linux调试器-gdb使用

1.1背景

    • 程序的发布方式有两种,debug模式和release模式
    • Linux gcc/g++出来的二进制程序,默认是release模式
    • 要使用gdb调试,必须在源代码生成二进制程序的时候, 加上-g 选项[重要]

    1.2开始使用

      • gdb binFile 退出: ctrl + d 或 quit 调试命令:
      • list/l 行号:显示binFile源代码,接着上次的位置往下列,每次列10行。[重要]
      • list/l 函数名:列出某个函数的源代码。
      • r或run:运行程序。[重要]
      • n 或 next:单条执行。[重要]
      • s或step:进入函数调用[重要]
      • break(b) 行号:在某一行设置断点[重要]
      • break 函数名:在某个函数开头设置断点
      • info break :查看断点信息。
      • finish:执行到当前函数返回,然后挺下来等待命令
      • print(p):打印表达式的值,通过表达式可以修改变量的值或者调用函数
      • p 变量:打印变量值。[重要]
      • set var:修改变量的值
      • continue(或c):从当前位置开始连续而非单步执行程序[重要]
      • run(或r):从开始连续而非单步执行程序
      • delete breakpoints:删除所有断点
      • delete breakpoints n:删除序号为n的断点[重要]
      • disable breakpoints:禁用断点
      • enable breakpoints:启用断点
      • info(或i) breakpoints:参看当前设置了哪些断点
      • display 变量名:跟踪查看一个变量,每次停下来都显示它的值
      • undisplay:取消对先前设置的那些变量的跟踪
      • until X行号:跳至X行
      • breaktrace(或bt):查看各级函数调用及参数
      • info(i) locals:查看当前栈帧局部变量的值
      • quit:退出gdb

      1.3理解


      二、Linux项目自动化构建工具-make/Makefile

      2.1背景

        • 会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力
        • 一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作
        • makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,
        • 比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。
        • make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。

        2.2实例代码

        #include <stdio.h>
        int main()
        {
            printf("hello Makefile!\n");
            return 0;
        }

        image.gif

        Makefile文件

        hello:hello.o
            gcc hello.o -o hello
        hello.o:hello.s
            gcc -c hello.s -o hello.o
        hello.s:hello.i
            gcc -S hello.i -o hello.s
        hello.i:hello.c
            gcc -E hello.c -o hello.i
        .PHONY:clean
        clean:
              rm -f hello.i hello.s hello.o hello

        image.gif

        2.3依赖关系

          • 上面的文件hello ,它依赖hell.o
          • hello.o , 它依赖hello.s hello.s , 它依赖hello.i
          • hello.i , 它依赖hello.c

          2.4依赖方法

            • gcc hello.* -option hello.* ,就是与之对应的依赖关系

            image.gif编辑

            2.5原理

            make是如何工作的,在默认的方式下,也就是我们只输入make命令。那么,

            1. make会在当前目录下找名字叫“Makefile”或“makefile”的文件。

            2. 如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到“hello”这个文件,并把这个文件作为最终的目标文件。

            3. 如果hello文件不存在,或是hello所依赖的后面的hello.o文件的文件修改时间要比hello这个文件新(可以用touch 测试),那么,他就会执行后面所定义的命令来生成hello这个文件。

            4. 如果hello所依赖的hello.o文件不存在,那么make会在当前文件中找目标为hello.o文件的依赖性,如果找到则再根据那一个规则生成hello.o文件。(这有点像一个堆栈的过程)

            5. 当然,你的C文件和H文件是存在的啦,于是make会生成 hello.o 文件,然后再用 hello.o 文件声明make的终极任务,也就是执行文件hello了。

            6. 这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。

            7. 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make根本不理。

            8. make只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,那么对不起,我就不工作啦。

            2.6项目清理

              • 工程是需要被清理的
              • 像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行。即命令——“make clean”,以此来清除所有的目标文件,以便重编译。
              • 但是一般我们这种clean的目标文件,我们将它设置为伪目标,用.PHONY 修饰,伪目标的特性是,总是被执行的。
              • 可以将我们的hello 目标文件声明成伪目标,测试一下。

              三、Linux第一个小程序-进度条

              3.1\r&&\n

                • 回车概念
                • 换行概念
                • 老式打字机的例子

                3.2行缓冲区概念

                #include <stdio.h>
                int main()
                {
                    printf("hello Makefile!\n");
                    sleep(3);
                    return 0;
                }

                image.gif

                3.3进度条代码

                #include <unistd.h>
                #include <string.h>
                int main()
                {
                    int i = 0;
                    char bar[102];
                    memset(bar, 0 ,sizeof(bar));
                    const char *lable="|/-\\";
                    while(i <= 100 ){
                        printf("[%-100s][%d%%][%c]\r", bar, i, lable[i%4]);
                        fflush(stdout);
                        bar[i++] = '#';
                        usleep(10000);
                    }
                    printf("\n");
                    return 0;
                }

                image.gif

                image.gif编辑

                相关实践学习
                阿里云图数据库GDB入门与应用
                图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
                目录
                相关文章
                |
                1月前
                |
                Linux C++
                Linux c/c++之makefile的基础使用
                Linux下C/C++项目中makefile的基本使用,包括基础、进阶和高级用法,以及如何创建和使用makefile来自动化编译过程。
                18 0
                Linux c/c++之makefile的基础使用
                |
                3月前
                |
                NoSQL Linux C语言
                Linux GDB 调试
                Linux GDB 调试
                65 10
                |
                3月前
                |
                NoSQL Linux C语言
                嵌入式GDB调试Linux C程序或交叉编译(开发板)
                【8月更文挑战第24天】本文档介绍了如何在嵌入式环境下使用GDB调试Linux C程序及进行交叉编译。调试步骤包括:编译程序时加入`-g`选项以生成调试信息;启动GDB并加载程序;设置断点;运行程序至断点;单步执行代码;查看变量值;继续执行或退出GDB。对于交叉编译,需安装对应架构的交叉编译工具链,配置编译环境,使用工具链编译程序,并将程序传输到开发板进行调试。过程中可能遇到工具链不匹配等问题,需针对性解决。
                102 3
                |
                3月前
                |
                NoSQL Linux 编译器
                内核实验(一):使用QEMU+GDB断点调试Linux内核代码
                如何配置环境并使用QEMU虚拟机结合GDB进行Linux内核代码的断点调试,包括安装QEMU、交叉编译工具链,编译内核以及通过GDB远程连接进行调试的详细步骤。
                160 0
                内核实验(一):使用QEMU+GDB断点调试Linux内核代码
                |
                4月前
                |
                Java Linux C++
                【Linux】Make和Makefile快速入门
                【Linux】Make和Makefile快速入门
                31 0
                |
                4月前
                |
                Java Linux 编译器
                编写和使用Linux Makefile
                编写和使用Linux Makefile
                |
                5月前
                |
                Linux
                【make/Makefile】Linux下进度条的设计与实现
                【make/Makefile】Linux下进度条的设计与实现
                |
                5月前
                |
                NoSQL 编译器 Linux
                【Linux】--- Linux编译器-gcc/g++、调试器-gdb、项目自动化构建工具-make/Makefile 使用
                【Linux】--- Linux编译器-gcc/g++、调试器-gdb、项目自动化构建工具-make/Makefile 使用
                90 0
                |
                6月前
                |
                NoSQL 搜索推荐 openCL
                【C/C++ 调试 GDB指南 】gdb调试基本操作
                【C/C++ 调试 GDB指南 】gdb调试基本操作
                391 2
                |
                3月前
                |
                NoSQL
                技术分享:如何使用GDB调试不带调试信息的可执行程序
                【8月更文挑战第27天】在软件开发和调试过程中,我们有时会遇到需要调试没有调试信息的可执行程序的情况。这可能是由于程序在编译时没有加入调试信息,或者调试信息被剥离了。然而,即使面对这样的挑战,GDB(GNU Debugger)仍然提供了一些方法和技术来帮助我们进行调试。以下将详细介绍如何使用GDB调试不带调试信息的可执行程序。
                108 0
                下一篇
                无影云桌面