【Linux-关于makefile的原理及知识】通过五次代码结构的迭代来直白展示
目标:test;依赖:test.c add.c sub.c mul.c div.c;命令:gcc test.c add.c sub.c mul.c div.c -o test;代码语言:javascriptAI代码解释#后面表示注释;#这是自定义变量OBJS、TARGET;#这是自定义变量的使用方法$(name);#这是模式规则%+文件类型,自动找到依赖.c生成目标.o;%.o:%.c#最后使用了
·
要求:在test.c中实现功能,其中引用到了add.c sub.c mul.c div.c中的函数,最后生成一个test执行文件:
第一步:描述变更,明确目标
目标:test; 依赖:test.c add.c sub.c mul.c div.c; 命令:gcc test.c add.c sub.c mul.c div.c -o test;
第一版
代码语言:javascript
AI代码解释
test:test.c add.c sub.c mul.c div.c
gcc test.c add.c sub.c mul.c div.c -o test
第二版(由于第一版会不停的更新.o中间文件,为了免去频繁更新的问题,我们将.o中间文件生成出来,利用.o和.c时间比较规则可以避免重新编译未发生改变的.c文件)
代码语言:javascript
AI代码解释
test:test.o add.o sub.o mul.o div.o
gcc test.o add.o sub.o mul.o div.o -o test
test.o:test.c
gcc -c test.c
add.o:add.c
gcc -c add.c
sub.o:sub.c
gcc -c sub.c
mul.o:mul.c
gcc -c mul.c
div.o:div.c
gcc -c div.c
第三版(利用自定义变量、自动变量、模式规则%来实现第三步的优化)
代码语言:javascript
AI代码解释
#后面表示注释;
#这是自定义变量OBJS、TARGET;
OBJS=test.o add.o sub.o mul.o div.o
TARGET=test
#这是自定义变量的使用方法$(name);
$(TARGET):$(OBJS)
gcc $(OBJS) -o $(TARGET)
#这是模式规则%+文件类型,自动找到依赖.c生成目标.o;
%.o:%.c
gcc -c $<-o $@
#最后使用了自动变量 $@ 目标 | $< 第一个依赖 | $^ 所有依赖;
第四版(两个函数:wildcard-查找指定目录下的制定类型文件;patsubst-匹配替换)
代码语言:javascript
AI代码解释
SRC=$(wildcard *.c)
OBJS=$(patsubst %.c, %.o, $(SRC))
TARGET=test
$(TARGET):$(OBJS)
gcc $(OBJS) -o $(TARGET)
%.o:%.c
gCC -C $<-o$@
第五版(最终版:伪目标clean示例,清除目录下指定类型文件)
代码语言:javascript
AI代码解释
# 使用$(...)来引用变量
SRC=$(wildcard *.c)
OBJS=$(patsubst %.c, %.o, $(SRC))
TARGET=test
# 编译目标文件并链接为可执行文件
$(TARGET): $(OBJS)
gcc $(OBJS) -o $(TARGET)
# 编译.c文件到.o文件
%.o: %.c
gcc -c $< -o $@
# 声明clean为伪目标
.PHONY: clean
# 清除所有.o文件和可执行文件
clean:
rm -rf $(OBJS) $(TARGET)
至此,加以运用,最重要的是多用~
更多推荐

所有评论(0)