Linux下的系统编程——makefile入门(四)

前言:

或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义。

一、makefile: 管理项目。

设置文件add.c div1.c sub.c hello.c

命名:makefile Makefile --- make 命令

1. 1 个规则:

目标:依赖条件

(一个tab缩进)命令

makefile中的规则

(1)目标的时间必须晚于依赖条件的时间,否则,更新目标

(2)依赖条件如果不存在,找寻新的规则去产生依赖条件。

ALL:指定 makefile 的终极目标。

(目的是确定最终退出的目标)

2. 2 个函数:

(1)src = $(wildcard ./*.c)

匹配当前工作目录下的所有.c 文件。将文件名组成列表,赋值给变量 src。 src = add.c sub.c div1.c

(2)obj = (**patsubst** %.c, %.o, (src))

将参数3中,包含参数1的部分,替换为参数2。 obj = add.o sub.o div1.o

clean: (没有依赖)

-rm -rf $(obj) a.out "-":作用是,删除不存在文件时,不报错。顺序执行结束。

3. 3 个自动变量:

(1)$@

在规则的命令中,表示规则中的目标。

(2)$^

在规则的命令中,表示所有依赖条件。

(3)$<

在规则的命令中,表示第一个依赖条件。如果将该变量应用在模式规则中,它可将

依赖条件列表中的依赖依次取出,套用模式规则。

4.模式规则:

%.o:%.c

gcc -c $< -o %@

(1)静态模式规则:

$(obj):%.o:%.c

gcc -c $< -o %@

(2)伪目标:

.PHONY: clean ALL

参数:

-n:模拟执行make、make clean 命令。

-f:指定文件执行 make 命令。 xxxx.mk

变化1:

变化2:

相关推荐
ZK_H6 分钟前
嵌入式c语言——关键字其6
c语言·开发语言·计算机网络·面试·职场和发展
特长腿特长10 分钟前
centos、ubantu系列机的用户和用户组的结构是什么?具体怎么配置?用户组权限怎么使用?这篇文章持续更新,帮助你复习linux的基础知识
linux·运维·centos
zzzyyy53813 分钟前
Linux环境变量
linux·运维·服务器
ambition2024240 分钟前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
pluvium2741 分钟前
记对 xonsh shell 的使用, 脚本编写, 迁移及调优
linux·python·shell·xonsh
cmpxr_42 分钟前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法
无级程序员1 小时前
centos7 安装 llvm-toolset-7-clang出错的问题解决
linux·centos
kebeiovo1 小时前
atomic原子操作实现无锁队列
服务器·c++
yashuk1 小时前
C语言实现PAT练习及算法学习笔记,还有SQLite介绍
c语言·sqlite·开源项目·算法学习·pat练习
CHHC18801 小时前
NetCore树莓派桌面应用程序
linux·运维·服务器