Makefile usage

简介:
如果你的程序是很多个c文件组成的, 某天你对其中的一个c文件做了更改。 其他的都不变。
如果要重新编译的话, 所有的c文件都重新编译显然是很浪费时间的.
gcc编译由4步骤组成, 可以看我前面的BLOG。
其中link前面的一个步骤是产生对象文件如a.c产生a.o的对象文件(gcc -c) .
link是把这些O文件组装成一个可执行文件的过程(gcc -o) .

也就是说如果要提高编译速度, 可以保存这些o文件即对象文件, 只编译变更过的c文件, 然后再link成可执行文件.
一般可以通过文件的时间改变来判断是否需要重新编译。例如 : 
通过c文件和o文件以及bin文件的时间比较哪个文件是变更过的.
Makefile usage - 德哥@Digoal - The Heart,The World.
 
Makefile usage - 德哥@Digoal - The Heart,The World.
 
那么只需要对变更的c文件重新生成o文件然后link. 或者拿最新的o文件link即可.
如果手工来判断, 实在是很繁琐.

还好这个可以交给make来搞定.
make 需要用到的是Makefile 或者 makefile.
makefile的语法 : 
1. target file冒号(一般是每个c文件都写一个targetfile , o文件. 最后是link后的bin文件)

2. depend file(如果target是o文件, 这部分包含了一个c文件和所有的h文件.(<>中的h文件不用写出);  如果是bin文件, 写出所有的o文件即可)
3. rule (如果targetfile是o文件, 这里写gcc -c c文件即可.  如果targetfile是bin文件, 那么gcc 所有的o文件 -o bin文件名)

文件内容和格式如图 : 
Makefile usage - 德哥@Digoal - The Heart,The World.
 
接下来是一个范例 : 
代码中包含1个H文件和2个C文件.
[root@db-172-16-3-150 zzz]# ll
total 16
-rw-r--r-- 1 root root 295 Aug  7 14:44 a.c
-rw-r--r-- 1 root root 107 Aug  7 14:33 encrypt.c
-rw-r--r-- 1 root root  26 Aug  7 14:17 encrypt.h
-rw-r--r-- 1 root root 210 Aug  7 15:21 makefile
encrypt.c的内容.
[root@db-172-16-3-150 zzz]# cat encrypt.c
//#include "encrypt.h"

void encrypt(char *msg) {
  while (* msg) {
    *msg = *msg ^ 31;
    msg++;
  }
}
encrypt.h的内容.
[root@db-172-16-3-150 zzz]# cat encrypt.h
void encrypt(char * msg);
a.c文件的内容.
[root@db-172-16-3-150 zzz]# cat a.c
#include <stdio.h>
#include <encrypt.h>

int main() {
  char msg[80];
  while(fgets(msg,80,stdin)) {
    printf("original msg:%s\n", msg);
    // encode
    encrypt(msg);
    printf("encoded msg:%s\n", msg);
    // decode
    encrypt(msg);
    printf("decoded msg:%s\n", msg);
  }
  return 0;
}
makefile的内容.
[root@db-172-16-3-150 zzz]# cat makefile 
encrypt.o: encrypt.c
        gcc -O3 -Wall -Wextra -Werror -g -c encrypt.c
a.o: a.c encrypt.h
        gcc -O3 -Wall -Wextra -Werror -I/root/zzz -g -c a.c
a: a.o encrypt.o
        gcc -O3 -Wall -Wextra -Werror -g a.o encrypt.o -o a

使用make 生成a文件的命令.
[root@db-172-16-3-150 zzz]# make a
gcc -O3 -Wall -Wextra -Werror -I/root/zzz -g -c a.c
gcc -O3 -Wall -Wextra -Werror -g -c encrypt.c
gcc -O3 -Wall -Wextra -Werror -g a.o encrypt.o -o a

生成a文件的过程中产生了一堆o文件.
[root@db-172-16-3-150 zzz]# ll
total 40
-rwxr-xr-x 1 root root 10349 Aug  7 15:33 a
-rw-r--r-- 1 root root   295 Aug  7 14:44 a.c
-rw-r--r-- 1 root root  6568 Aug  7 15:33 a.o
-rw-r--r-- 1 root root   107 Aug  7 14:33 encrypt.c
-rw-r--r-- 1 root root    26 Aug  7 14:17 encrypt.h
-rw-r--r-- 1 root root  3144 Aug  7 15:33 encrypt.o
-rw-r--r-- 1 root root   210 Aug  7 15:21 makefile


修改encrypt.c : 
删除注释行. 再次make a. 我们看到encrypt.c 重新生成了o文件, 并且重新link了bin文件.
[root@db-172-16-3-150 zzz]# make a
gcc -O3 -Wall -Wextra -Werror -g -c encrypt.c
gcc -O3 -Wall -Wextra -Werror -g a.o encrypt.o -o a

注意rule部分必须是tab开头的. 否则会没有用.

还可以在makefile中使用环境变量. 例如 : 
Makefile usage - 德哥@Digoal - The Heart,The World.
目录
相关文章
|
4天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
15天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1313 5
|
2天前
|
监控 JavaScript Java
基于大模型技术的反欺诈知识问答系统
随着互联网与金融科技发展,网络欺诈频发,构建高效反欺诈平台成为迫切需求。本文基于Java、Vue.js、Spring Boot与MySQL技术,设计实现集欺诈识别、宣传教育、用户互动于一体的反欺诈系统,提升公众防范意识,助力企业合规与用户权益保护。
|
14天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
1356 87
|
2天前
|
JavaScript Java 大数据
基于JavaWeb的销售管理系统设计系统
本系统基于Java、MySQL、Spring Boot与Vue.js技术,构建高效、可扩展的销售管理平台,实现客户、订单、数据可视化等全流程自动化管理,提升企业运营效率与决策能力。
|
4天前
|
弹性计算 安全 数据安全/隐私保护
2025年阿里云域名备案流程(新手图文详细流程)
本文图文详解阿里云账号注册、服务器租赁、域名购买及备案全流程,涵盖企业实名认证、信息模板创建、域名备案提交与管局审核等关键步骤,助您快速完成网站上线前的准备工作。
194 82
2025年阿里云域名备案流程(新手图文详细流程)