Makefile的基本格式
target:depend1 depend2
<tab> action1
<tab> action2
注意:
1.命令行必须要以 tab 键开头。
2.在makefile中 # 代表批注。
3.目标与目标文件之间要以 : 隔开。
一个例子
APP=link
#GCC=arm-linux-gcc
GCC=gcc
SRCS+=linker.c add.c
LIBNAME=ly
all: shared_lib static_lib
${GCC} main.c -o ${APP} -L. -l${LIBNAME}
shared_lib:
@${GCC} -shared -fpIC ${SRCS} -o lib${LIBNAME}.so
static_lib:
@${GCC} -c ${SRCS}
@ar -rcs lib${LIBNAME}.a*.o
install:
cp ${APP} /tftp
clean:
rm -f *.o
distclean: clean
rm -f ${APP}
rm -f *.a
rm -f *.so
文件开头定义变量APP、GCC等(变量左边无tab),变量与变量内容间以等号隔开,运用变量时,以${变量}或$(变量)使用。
该makefile中共有6个目标,all依赖于文件shared_lib和static_lib,在当前路径下的ly函数库编译文件main.c生成可执行文件link。后略。
三个比较有用的内部变量。$@ 扩展成当前规则的目的文件名, $< 扩展成依靠列表中的第一个依靠文件,而 $^ 扩展成整个依靠的列表(除掉了里面所有重复的文件名)。
环境变量取用规则
make命令行后的环境变量 > makefile中指定的环境变量 > shell原本具有的环境变量