• 基本概念(2)——make、ninja、nmake、jom


    不用在命令行手动输入编译命令,把这些命令写到一个txt文件内,调用make或者ninja工具自动执行编译过程

    make与makefile

    多数内容copy自youtube的一个视频:https://www.youtube.com/watch?v=E1_uuFWibuM
    执行环境:原作者是在Linux下做的视频,而我使用的是win10,win10下使用mingw-w64、msys2来安装win下的gcc与make工具。安装mingw-w64和msys2(我安装后是不带make工具的,pacman命令安装的make)后配置下环境变量就可以使用gcc和make工具了。文本编辑器使用的是VS code。
    一个可能用到的知识补充:https://www.biaodianfu.com/cygwin-ming-msys.html
    mingw-w64官网:https://mingw-w64.org/doku.php/start
    msys2官网:http://www.msys2.org/

    为什么要用makefile

    (1)简单编译一个c文件

    命令:
    gcc main.c -o main.exe
    执行后会得到一个main.exe的文件。在控制台中执行下:

    这样就得到了输出。但是,如果.c文件很多,参数也很多,gcc的命令就会很长,源文件做一点点的修改就要执行一次冗长的gcc命令。这时候就可以使用make工具,写一个makefile文件来执行编译。makefile的写法:

    target是要编译的结果,冒号后面的dependencies是依赖,command是要执行的命令(command前面是一个tab不是空格),例如:

    去控制台执行一下:

    多个c文件的情况

    为了试验,写下如下代码,共三个文件:

    如果直接使用gcc命令编译的话,命令是:gcc main.c sayHello.c -o main.exe 如果文件特别多,只修改部分文件然后执行所有文件全部编译的话,明显会浪费时间。所以,这种情况下,就是对每个c文件单独编译,比如上图中的sayHello.c单独编译成sayHello.o,最后链接到main.c文件。借用原视频中的一个图来说明下:

    那么,针对我第一张图中sayHello.c的makefaile就应该想下面这样写:

    main.exe: main.c sayHello.o
        gcc main.c sayHello.o -o main.exe
    sayHello.o: sayHello.c
        gcc -c sayHello.c -o sayHello.o
    


    注意,按照顺序,是从上向下写,但编译是从下向上编译,也就是说,先编译sayHello.c成sayHello.o,然后编译main.c sayHello.o。注意上面编译sayHello.c的时候有个-c参数,意思是把源文件编译成.o的中间文件而不是.exe的可执行文件。
    去执行下:

    至此,已经得到的编译的结果并且执行也没问题,但是,由于编译过程中出现了中间文件*.o,编译后就没用了,如果有很多的话一个个删除不现实,所以在makefile中可以添加一个clean,如下:

    main.exe: main.c sayHello.o
        gcc main.c sayHello.o -o main.exe
    sayHello.o: sayHello.c
        gcc -c sayHello.c -o sayHello.o
    clean:
        rm *.o
    

    执行下make clean就可以清理了:

    makefile文件中的变量


    上图中有三个c文件,分别都使用了“gcc”这个名字,试想下,如果有一百个c文件,那么就要写一百次gcc,如果换编译器,就要每一个都要修改,所以,使用一个变量来代替“gcc”就显得很有必要了。

    执行效果如下:

    下面也是变量的用法示例:

    多个main函数的情况

    上图是原视频中的makefile文件,换到win下,需要在可执行文件下添加.exe,例如我的例子就可以写成下面这样:
    1、目录文件,我修改了两个main文件一个是main1.c另外一个是main2.c, 这两个文件内容是完全一样的

    2、修改makefaile内容,变化部分用红色标出

    3、去执行下

    nmake

    可以理解成微软家的make,随着vs安装

    jom

    qt的定制nmake
    jom是nmake的克隆,可支持并行执行多个独立命令。它基本上增加了-j命令行开关,类似于GNU make。原始博客文章仍可以在Qt博客上找到。 https://wiki.qt.io/Jom
    一般make可以加一个参数-j 表示使用多少个线程来编译,-j4就表示使用4个线程编译.
    linux下使用make,而在windows上面使用nmake,是vs提供的一个东西,但是有很个坑的事,就是nmake不支持-j这个参数,,也是就是说它是单线程编译,Qt为了解决这样子的一个问题,弄出一个jom.exe,这和make的功能基本是一样的,但是他比nmake多出来的就是,-j这个参数.也就是说它支持多线程编译.
    来自 https://bbs.csdn.net/topics/392205042

  • 相关阅读:
    SpringMVC配置双数据源,一个java项目同时连接两个数据库
    Jquery EasyUI封装简化操作
    C#中Math.Round()实现中国式四舍五入
    Entity Framework6 with Oracle
    在C#中如何读取枚举值的描述属性
    MVC视图中处理Json
    ASP.NET MVC中实现多个按钮提交的几种方法
    asp.net MVC的EF与easyui DataGrid数据绑定
    idea maven下载包太慢了如何解决
    ssh报错No operations allowed after connection closed.Connection was implicitly clos
  • 原文地址:https://www.cnblogs.com/feipeng8848/p/14306420.html
Copyright © 2020-2023  润新知