标签:makefile
0.前言#include <stdio.h> #include <test-add.h> #include <test-sub.h> int main(void) { int a = 3; int b = 2; printf("a=%d\n", a); printf("b=%d\n", b); #ifdef TEST_ADD printf("a+b=%d\n", add(a,b)); #endif #if TEST_SUB printf("a-b=%d\n", sub(a,b)); #endif return 0; }
# 指令编译器和选项 CC=gcc CFLAGS=-Wall -std=gnu99 # 宏定义 DEFS = -DTEST_ADD -DTEST_SUB=1 CFLAGS += $(DEFS) # 目标文件 TARGET=test # 源文件 SRCS = test.c ./test-add/test-add.c ./test-sub/test-sub.c # 头文件查找路径 INC = -I./test-add -I./test-sub # 目标文件 OBJS = $(SRCS:.c=.o) # 链接为可执行文件 $(TARGET):$(OBJS) # @echo TARGET:$@ # @echo OBJECTS:$^ [tab]$(CC) -o $@ $^ clean: [tab]rm -rf $(TARGET) $(OBJS) # 连续动作,请清除再编译链接,最后执行 exec:clean $(TARGET) [tab]@echo 开始执行 [tab]./$(TARGET) [tab]@echo 执行结束 # 编译规则 $@代表目标文件 $< 代表第一个依赖文件 %.o:%.c [tab]$(CC) $(CFLAGS) $(INC) -o $@ -c $<
Linux学习笔记——例说makefile 增加宏定义,布布扣,bubuko.com
标签:makefile
原文地址:http://blog.csdn.net/xukai871105/article/details/37079159