-
首先注意missing seprator 错误,原因是在每个块下的第二行需要用tab进行对齐
-
Makefile 用到环境变量时,不能直接使用shell脚本中环境变量的形式,比如不能使用 J A V A H O M E , 而 是 要 使 用 JAVA_HOME,而是要使用 JAVAHOME,而是要使用(JAVA_HOME)
-
注意编译完成后最好不要保留中间结果,因为下一次编译可能会出问题,在all所需的步骤里写个clean。
-
addprefix 为变量中的每个元素添加前缀
INCLUDE_DIR=usr/java/jdk1.8.0_25/include \
usr/java/jdk1.8.0_25/include/linux
INCLUDE_FLAG=$(addprefix -I,${INCLUDE_DIR})
all:
ls ${INCLUDE_FLAG}
-
gcc -c 表示只编译不连接,加-c会只生产.o文件,用ld连接后才生成可执行文件。不加-c会直接生成可执行文件。
-
如果指令前不加 @ ,执行时会将指令原样输出
-
通配符% 好像不适用于变量,只适用于常量以及静态模式。变量替换可以用
patsubst