• Linux下的自动化构建工具之make/makefile的用法详解


    一、make和makefile的区别

    make是一个命令,makefile是一个文件。

    二、makefile的原理

    1、make的原理详解

    每次生成可执行文件时需要输入一长串的gcc········指令是不是感觉很麻烦?makefile存在的意义是为了项目的构建。需要表明依赖关系和依赖方法。

    2、临时文件的清理

    1

    2

    3

    4

    5

    mycode:mycode.c

        gcc mycode.c -o mycode

    .PHONY:clean                                                                                              

    clean:

        rm -f mycode

    .PHONY表示被该关键字修饰的对象是一个伪目标。(该伪目标总是可被执行)

    我们在编写完makefile后,make一下,就能生成对应的可执行程序。如果依赖的文件列表没有发生修改,gcc通过判断mycode.c的Modify time早于mycode的Modify time,说明依赖文件列表没有修改,那么再次make将会失败;反之,重新编译将会成功。

    不过多次make clean却不会失败,因为clean被.PHONY修饰,变成了一个伪目标,所以clean总是可被执行。

    3、文件的三个时间

    1

    2

    3

    4

    5

    6

    7

    8

    9

    [root@VM-4-11-centos ~]# stat 106/text.c

      File: ‘106/text.c'

      Size: 0             Blocks: 0          IO Block: 4096   regular empty file

    Device: fd01h/64769d    Inode: 658416      Links: 1

    Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)

    Access: 2022-09-17 21:13:21.098656019 +0800//最近访问

    Modify: 2022-09-17 21:13:21.098656019 +0800//最近修改

    Change: 2022-09-17 21:13:21.098656019 +0800//最近改动

     Birth: -

    1、读取文件时,Access time被改变,而Modify、Change time不会被改变(为防止文件被频繁访问修改Access time,优化为多次访问才修改一次该时间)

    2、修改文件时,三个时间都会被改变

    3、修改属性时,Change time被改变,而Access、Modify time不会被改变

    三、makefile的推导规则

    makefile会自己逐步寻找依赖文件列表,如果没找到对于依赖文件,将会继续向下寻找该依赖文件的依赖方法。

    四、实现一个进度条

    1、缓冲区问题

    1

    2

    3

    4

    5

    6

    7

    8

    9

    #include    

    #include    

    int main()   

    {   

        printf("hello world\n");//如果这里没有\n,程序将会在3秒后执行打印

        //fflush(stdout);//fflush会立即刷新缓冲区

        sleep(3);   

        return 0;   

    }  

    因为\n才会刷新缓冲区(\r等不会),这个程序printf执行完之后,将会休眠3秒,如果没有\n或者fflush手动刷新缓冲区,hello world将会存放至缓冲区,程序结束后才执行打印。

    2、实现倒计时程序

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    #include    

    #include    

    int main()   

    {   

        int cnt=10;   

        while(cnt)   

        {   

            printf("%2d\r",cnt);//2d控制刷新两位,\r表示回车                                                                                  

            fflush(stdout);//手动刷新缓冲区  

            sleep(1);   

            --cnt;   

        }   

        return 0;   

    能够实现从10到计时的程序。

    3、进度条的实现

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    //.h文件   

    #pragma once                                                                                              

    #include                                                          

    #include                                          

    #include                                                                                                                       

    #define NUM 101                                                                     

    #define STYLE '*'                                                                              

    extern void processOn();

    //.c文件

    #include "process.h"                                                                                          

    void processOn()   

    {   

        int cnt=0;   

        char bar[NUM];   

        memset(bar,'\0',NUM);   

        char type[4]={'|','/','-','\\'};   

        while(cnt<=100)   

        {   

            //-100表示占据屏幕100个空间并左对齐,%%转义为%

            printf("[%-100s][%d%%][%c]\r",bar,cnt,type[cnt%4]);  

            bar[cnt++]=STYLE;   

            fflush(stdout);   

            usleep(50000);   

        }   

        printf("\n");   

    }

    makefile中不用写头文件,编译器自己会去找。

    <>查找方式:直接去库目录下查找,如果找不到,报编译错误;

    ""查找方式:先去代码所在的路径下查找,如果找不到,再去库目录下查找,如果找不到,报编译错误。

  • 相关阅读:
    【C++】继承 ⑥ ( 类型兼容性原则 | 父类指针 指向 子类对象 | 使用 子类对象 为 父类对象 进行初始化 )
    如何做系统架构设计
    在 Ubuntu 中卸载 Microsoft Edge 浏览器
    abp(net core)+easyui+efcore实现仓储管理系统——ABP升级7.3上(五十八)
    力扣刷题-哈希表-三数之和
    C++:指针
    MySQL进阶之SQL优化、视图、存储过程
    01-win10安装Qt5
    卓越领先!安全狗入选2023年福建省互联网综合实力50强
    徒手撸设计模式-组合模式
  • 原文地址:https://blog.csdn.net/sinat_40572875/article/details/127976531