makefile学习笔记
2014-03-26 15:12
246 查看
学习makefile笔记
一个我个人觉得非常实用的例子:
eg:在当前目录下有a.cpp and b.cpp 现在写一个makefile,将这些文件编译出对应的.o文件。
begin:
1 2 src=$(wildcard *.c) 3 dir=$(notdir $(src)) 4 obj=$(patsubst %.c,%.o,$(dir) ) 5 6 all: $(obj) 7 @echo src:$(src) 8 @echo dir:$(dir) 9 @echo obj:$(obj) 10 @echo "end" 11 $(obj): %.o: %.c 12 gcc -c $(CFLAGS) $< -o $@ 13 clean: 14 -@rm -rf *.o
输出结果为:
gcc -c char.c -o char.o
gcc -c test_sizeof.c -o test_sizeof.o
gcc -c transfer.c -o transfer.o
src:char.c test_sizeof.c transfer.c
dir:char.c test_sizeof.c transfer.c
obj: char.o test_sizeof.o transfer.o
end
#wildcard把 指定目录下的所有后缀是c的文件全部展开
a.cpp b.cpp
#notdir把展开的文件去除掉路径信息
a.cpp b.cpp
#patsubst把$(dir)中的变量符合后缀是.c的全部替换成.o
#CFLAGS: 指定头文件(.h文件)的路径,如:CFLAGS=-I/usr/include -I/path/include。同样地,安装一个包时会在安装路径下建立一个include目录,当安装过程中出现问题时,试着把以前安装的包的include目录加入到该变量中来。
#在每条命令前加上@符号,可以隐藏makefile打印出当前命令本身
#在命令前加上一个“-”号的意思是,忽略该条命令的错误,继续执行。等同于-i i是--ignore-errors的缩写。
今天学习了makefile中的“命令包”好“目标变量”
命令包:eg:
1 src=$(wildcard *.c) 2 dir=$(notdir $(src)) 3 obj=$(patsubst %.c,%.o,$(dir) ) 4 5 define two_line 6 echo "this is two_line:one" 7 echo "this is two_line:two" 8 endef 9 10 all: $(obj) 11 @echo $(src) 12 @echo $(dir) 13 @echo $(obj) 14 @echo "end" 15 @$(two_line) 16 17 $(obj): %.o: %.c 18 gcc -c $(CFLAGS) $< -o $@ 19 clean: 20 rm -rf *.o
其中5~8行定义了这个命令包,two_line是这个命令包的名字,在define和endef之间的命令就是这个命令包的内容,在第15行调用了这个命令包。结果和想象的一样,不用过多解释。
目标变量:
这个特性很有用,我们设置了一个变量,这个变量只在特定的目标中起作用。
eg:
1 src=$(wildcard *.c) 2 dir=$(notdir $(src)) 3 obj=$(patsubst %.c,%.o,$(dir) ) 4 5 define two_line 6 echo "this is two_line:one" 7 echo "this is two_line:two" 8 endef 9 10 all: cc = gcc 11 12 all: $(obj) 13 @echo $(src) 14 @echo $(dir) 15 @echo $(obj) 16 @echo "end" 17 @$(two_line) 18 19 $(obj): %.o: %.c 20 $(cc) -c $(CFLAGS) $< -o $@ 21 clean: 22 rm -rf *.o 23 24第十行中,我们在all这个目标中定义 cc=gcc,只在这个目标规则下,$(cc) = gcc
相关文章推荐
- 学习笔记——Makefile中的=与:=
- makefile学习笔记
- 初识Makefile:学习笔记
- Makefile学习笔记
- Makefile 学习笔记(三)实例
- Makefile学习笔记5
- MAKEFILE 学习笔记 —— 实用功能
- Linux 学习笔记之Makefile单个c文件的编写
- makefile 学习笔记
- Linux学习笔记——例说makefile 增加自定义共享库
- Makefile的学习笔记
- Linux学习笔记——例说makefile 增加宏定义
- makefile学习笔记2
- Makefile学习笔记6
- linux环境arm裸机程序学习笔记1----makefile,中断,下载程序方法
- Makefile 学习笔记:
- Linux 我的第一个makefile(Linux指令学习笔记)
- 笔记:学习vc之makefile
- Make编译学习笔记(一)Makefile基础
- gcc gdb makefile学习笔记