makefile中使用变量及函数(3.注意.o输出路径问题)

时间:2021-12-28 12:43:00



延伸上一篇文章

makefile基础学习

http://blog.csdn.net/zhouzhenhe2008/article/details/55117592


1.举例makefile中使用变量的例子


cc = gcc
CFLAGS = -Wall -O -g
OBJS = hello1.o hello2.o hello_main.o
TARGET = helloworld
$(TARGET):$(OBJS)
$(CC) -o $(TARGET) $(OBJS)
@echo "=======finish========="
hello_main.o:hello_main.c
$(CC) -c hello_main.c -o hello_main.o
hello1.o:hello1.c
$(CC) -c hello1.c -o hello1.o
hello2.o:hello2.c
$(CC) -c hello2.c -o hello2.o
clean:
rm $(OBJS) $(TARGET) -rf
@echo "=============clean ok========"


makefile中使用变量及函数(3.注意.o输出路径问题)


(1)CC、CFLAGS 、OBJS、TARGET都是变量,引用变量,需要在变量的格式   :    $(变量名)    。

(2)CFLAGS = -Wall -O -g配置编译器设置,并把他赋值给CFLAGS变量,其中-Wall:输出所有警告信息,

-O:编译时进行优化,-g:编译debug版本。


2.使用函数


cc = gcc
CFLAGS = -Wall -O -g
OBJS = hello1.o hello2.o hello_main.o
TARGET = helloworld
$(TARGET):$(OBJS)
$(CC) -o $(TARGET) $(OBJS)
@echo "=======finish========="
%.o:%.c
$(CC) $(CFLAGS) -c $< -o $@
SRC = $(wildcard *.c)
OBJS = $(patsubst %.c,%.o,$(SRC))
clean:
rm $(OBJS) $(TARGET) -rf
@echo "=============clean ok========"


makefile中使用变量及函数(3.注意.o输出路径问题)



(1)在makefile中,通配符会自动展开,但在变量的定义和引用时,通配符将失效,需要使用函数wildcard  , 如 : $(wildcard PATTERN...)。

(2)patsubst函数,用于匹配替换,有3个参数,第一个是需要匹配的式样,第二个表示用什么来替换它,第三个是需要被处理的由分隔的列表,

(3)%.o:%.c
$(CC) $(CFLAGS) -c $< -o $@

把所有的.c文件编译成.o文件

$@扩展成当前规则的目的文件名

$<扩展成依靠表中第一个依靠文件

$^扩展成整个依靠的列表



3.指定.o生成到别的目录下的情况

cc = gcc
CFLAGS = -Wall -O -g
PWD_OUT := /share/out
PWD_SRC := /share/src

OBJS := $($(PWD_OUT)hello1.o)
OBJS += $($(PWD_OUT)hello2.o)
OBJS += $($(PWD_OUT)hello_main.o)

SRCS := $($(PWD_SRC)hello1.c)
SRCS += $($(PWD_SRC)hello2.c)
SRCS += $($(PWD_SRC)hello_main.c)

TARGET = helloworld
$(TARGET):$(OBJS)
$(CC) -o $(TARGET) $(OBJS)
@echo "=======finish========="
##非常重要的一步,%.o前加上路径是非常有必要的
$(PWD_OUT)/%.o:%.c
$(CC) $(CFLAGS) -c SRCS

clean:
rm $(OBJS) $(TARGET) -rf
@echo "=============clean ok========"