首页 > 其他分享 >自动化构建工具make/makefile详解

自动化构建工具make/makefile详解

时间:2023-11-02 15:01:35浏览次数:56  
标签:文件 依赖 make makefile 编译 详解 mycode

一、工具介绍

1.1为什么需要使用自动化项目构建工具呢

在我看来,在平时写较少代码,只有1个源文件的时候,用make和不用make感觉差别不大,但是当项目源文件一多,需要一个个的去输入gcc 进行编译,显然是十分麻烦的。所以make这个工具可以极大的提高项目完成后的测试工作。


1.2make/makefile介绍

makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。

make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。qt中有qmake、cmake可见,makefile都成为了一种在工程方面的编译方法。

一般在我们的项目进行编译是需要将make和makefile一起使用。


二、make和makefile使用示例

2.1 创建两个文件

<1>touch makefile   /   touch Makefile

<2> touch mycode.c

自动化构建工具make/makefile详解_目标文件

2.2编辑makefile/Makefile

指令:vim makefile

自动化构建工具make/makefile详解_目标文件_02

编辑如下内容:

mycode:mycode.c
gcc -o mycode mycode.c -std=c99
clean:
rm -f mycode log.txt

自动化构建工具make/makefile详解_目标文件_03

2.3 在mycode.c编写代码

执行make指令

自动化构建工具make/makefile详解_依赖关系_04

自动化构建工具make/makefile详解_目标文件_05

可以看到mycode的可执行文件,输出结果

自动化构建工具make/makefile详解_make/makefile_06

2.4清理项目文件

指令:make clean

自动化构建工具make/makefile详解_源文件_07

执行make clean 可以看到mycode的可执行文件被清理掉了。



三、make和makefile实现原理

3.1依赖关系

什么是依赖关系,通俗的来说,就是我的生成依赖我所指向的这个文件。那么我们拿一个例子来看。

自动化构建工具make/makefile详解_目标文件_08

这里mycode是项目生成的可执行文件,mycode依赖于源文件mycode.c进行编译创建,如果进行编译创建呢?这里就得引入依赖的方法

3.2依赖方法

依赖方法是指,源文件通过依赖方法生成对应的可执行文件,如下就是一个依赖关系的语句。在我看来就是gcc对文件的编译语句,只是把它封装了自动化进行指定,编译指定的源文件。

自动化构建工具make/makefile详解_目标文件_09

3.3 原理

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

  1. make会在当前目录下找名字叫“Makefile”或“makefile”的文件。
  2. 如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到“mycode.c”这个文件,并把这个文件作为最终的目标文件。
  3. 这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
  4. 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错, 而对于所定义的命令的错误,或是编译不成功,make根本不理。
  5. make只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,那么对不起,make就不工作啦。

3.4项目清理

  1. 工程是需要被清理的

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











标签:文件,依赖,make,makefile,编译,详解,mycode
From: https://blog.51cto.com/u_15831056/8147065

相关文章

  • STL之红黑树的模拟实现(万字长文详解)
    STL之红黑树的模拟实现红黑树的概念红黑树,是一种二叉搜索树,但在每个结点上增加一个存储位表示结点的颜色,可以是Red或Black。通过对任何一条从根到叶子的路径上各个结点着色方式的限制,==红黑树确保没有一条路径会比其他路径长出俩倍==,因而是==接近平衡==的。==意思就是最长路......
  • 关于pacemaker集群stonith:fence_azure_arm资源-SP-服务主机-密码过期的处理方法
    在pacemaker中,一般都会创建一个stonith资源(ShootTheOtherNodeInTheHead),笔者因为是在Azure平台、于是使用的为 stonith:fence_azure_arm最近发现有一个与之关联的服务主体的密码过期了,导致状态异常,通过pcsstatus可以看到FailresourceActions信息FailedResourceAc......
  • PHP大文件分割上传详解
    这篇文章主要为大家详细介绍了PHP大文件分割上传,PHP分片上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下服务端为什么不能直接传大文件?跟php.ini里面的几个配置有关upload_max_filesize=2M //PHP最大能接受的文件大小post_max_size=8M //PHP能收到的最大POST值'me......
  • 高性能渲染——详解Html Canvas的优势与性能
    本文由葡萄城技术团队原创并首发。转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。一、什么是Canvas想必学习前端的同学们对Canvas都不陌生,它是HTML5新增的“画布”元素,可以使用JavaScript来绘制图形。Canvas元素是在HTML5中新增......
  • keystone服务的详解
    一:keystone服务作用:1:提供其余组件的所有认证服务,令牌的管理2:用户管理:验证用户的身份合法流程就是openstack上的用户,进行一个初始化,将信息存储在数据库里面去,然后第一次登录的时候,会去数据库里面去找数据进行校验,然后返回用户一个令牌,以后用户有这个令牌的话,使用某些服务的时候......
  • 【python爬虫】80页md笔记,0基础到scrapy项目高手,第(3)篇,requests网络请求模块详解
    本文主要学习一下关于爬虫的相关前置知识和一些理论性的知识,通过本文我们能够知道什么是爬虫,都有那些分类,爬虫能干什么等,同时还会站在爬虫的角度复习一下http协议。完整版笔记直接地址:请移步这里共8章,37子模块,总计56668字requests模块本阶段本文主要学习requests这......
  • 19、模糊查询操作符详解
    模糊查询:本质是比较运算符运算符语法描述isnullaisnull如果操作符为null,则结果为真isnotnullaisnotnull如果操作符不为null,则结果为真betweenabetweenbandc若a在b和c之间,则结果为真likealikebSQL匹配,如果a匹配到b,则结果为真inain(a1......
  • google test 之 TEST_F详解
    一、基本概念:googletest三种测试用例写法:TEST(test_suite_name,test_name)第一种是最基本写法:#include<gtest/gtest.h>intadd(inta,intb){returna+b;}TEST(testAdd,testArrayAdd){inta[]={1,2,3,4,5};intb[]={5,6,7,8,9};int......
  • hadoop 基础组件详解
           ......
  • Java 线程池详解,图文并茂,还有谁不会?!
    来源:blog.csdn.net/mu_wind/article/details/113806680初识线程池我们知道,线程的创建和销毁都需要映射到操作系统,因此其代价是比较高昂的。出于避免频繁创建、销毁线程以及方便线程管理的需要,线程池应运而生。线程池优势降低资源消耗:线程池通常会维护一些线程(数量为corePool......