Makefile 使用要点

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/yanhe156/article/details/83153665
  1. 首先注意missing seprator 错误,原因是在每个块下的第二行需要用tab进行对齐

  2. Makefile 用到环境变量时,不能直接使用shell脚本中环境变量的形式,比如不能使用 J A V A H O M E 使 JAVA_HOME,而是要使用 (JAVA_HOME)

  3. 注意编译完成后最好不要保留中间结果,因为下一次编译可能会出问题,在all所需的步骤里写个clean。

  4. 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}
  1. gcc -c 表示只编译不连接,加-c会只生产.o文件,用ld连接后才生成可执行文件。不加-c会直接生成可执行文件。

  2. 如果指令前不加 @ ,执行时会将指令原样输出

  3. 通配符% 好像不适用于变量,只适用于常量以及静态模式。变量替换可以用patsubst

猜你喜欢

转载自blog.csdn.net/yanhe156/article/details/83153665