make 常用选项
make[-f file] [options] [target]
make 默认在当前目录中查找GUNmakefile、makefile 及 Makefile 文件作为make的输入文件
-f 指定文件作为输入文件
-v 显示版本号
-n 只输出命令不执行, 一般作为测试
-s 执行命令不显示命令,
-w 显示执行前和执行后的路径
-C dir 指定makefile 所在的目录
gcc/g++编译流程:
gcc–lstdc++ xxxx.cpp 直接从源代码得到可执行文件。
预处理 gcc –E xxx.cpp > xxx.i
编译 gcc –S xxx.i 得到名为 xxx.s 的汇编文件
汇编 gcc –c xxx.s 得到名为 xxx.o 的二进制文件
链接 gcc –lstdc++ xxx.o 得到 a.out 的可执行文件
makefile 中的变量
系统变量
$* 不包括扩展名的目标文件名称
$+ 所有依赖文件,以空格分隔
$< 规则中的第一个条件
$? 所有时间戳比目标文件晚的依赖文件,以空格分隔
$@ 目标文件的完整名称
$^ 所有不重复的依赖文件,以空格分隔
$% 如果目标文件是归档成员,则该变量表示目标的归档成员名称
系统常量(make –p 查看)
AS 汇编文件的名称 默认as
CC C编译器名称 默认cc
CPP C预编译器名称 默认cc –E
CXX C++编译器名称 默认 g++
RM 文件删除程序名称 默认 rm -f
makefile 伪目标
伪目标: .PHONT: clean
声明目标为伪目标之后, makefile将不会判断目标是否存在或该目标是否需要更新
makefile 模式匹配
%.o:%.cpp .o依赖于对应的.cpp
Wildcard $(wilcard./*.cpp) 获取当前目录下所有的.cpp 文件
Patsubst $(patsubst%.cpp, %o, ./*.cpp) 将对应的.cpp文件替换成.o文件名
makefile 编译动态库
-fPIC 产生位置无关的代码
-shared 共享
-l(小L)指定动态库
-L 指定库文件搜索目录,默认只链接共享目录
-I(大i)指定头文件目录, 默认为当前目录
Makefile 通用部分作为公共头文件
Makefile中都是先展开所有变量再调用指令
= 赋值,使用最终值,不管变量调用写在赋值前还是赋值后,调用时都是取最终值。
:= 赋值 只受当前行及之前的代码影响。不会受后面的赋值影响。
举例:
1:
TARGET = a
OBJ = a.o b.o c.o
$(TARGET):$(OBJ)
$(CXX) $^ -O $@
%.o:%.cpp
gcc –c $^ -o $@
clean:
$(RM) $(TARGET) $(OBJ)
2: 精简
SOURCE=$(wilcard ./*.cpp ./.c)
OBJ=$(patsubst %.cpp,%.o, $(SOURCE)) #替换 .cpp-> .o
OBJ:= $(patsubst %.c,%.o, $(OBJ)) #替换 .c-> .o
.PHONY:clean
$(TARGET):$(OBJ)
$(CXX) $^ -O $@
clean:
$(RM) $(TARGET) $(OBJ)
3:ARM
RM = rm
CC =arm-xilinx-linux-gnueabi-gcc
CPP =arm-xilinx-linux-gnueabi-g++
AR =arm-xilinx-linux-gnueabi-ar
# target library
TGT_NAME = xxxx
ROOTDIR = ../
BINDIR = bin
TARGET =./$(TGT_NAME)
#
# Dependency List
#
MODULES = $(wildcard *.c)
CDBGFMT = -gdwarf-2
CFLAGS = -Wall
INCLUDES = -I"../include"
LIBRARYS = -lxxx
LIBPATH = -L../lib
CFLAGS += -DDEBUG -O0 $(CDBGFMT)
CFLAGS += $(INCLUDES)
OBJECTS = $(MODULES:.c=.o)
.SUFFIXES: .c
.c.o:
$(CC) $(CFLAGS) -c $<-o $@
$(TARGET): $(OBJECTS)
$(CC) -o $(TARGET)$(OBJECTS) $( LIBRARYS) $( LIBPATH)
clean:
$(RM) -rf ./*.o
$(RM) -rf ./$(TARGET)