1.gcc 的使用:
gcc 常用的选项:
-c: 生成.o 文件
-o: 指定生成的名字
-I: 添加头文件搜索路径
-L: 添加库搜索路径
例子:
1.c 1.h main.c, 把它们编译成一个可执行程序 main
在终端上编译:
gcc 1.c main.c -o main
<tab>执行命令
备注:
目标----我们执行 make 想得到的东西
依赖文件----得到目标所需要的文件(用空格隔开)
执行命令---- 得目标所需要执行的命令
make 工具的执行过程:
在终端上输入: make--->在当前目录下找 Makefile 文件
----->以第一个目标为最终的目标开始执行
make 工程有什么好处?
1) 方便编译程序
2 ) 编译速度快
main:1.c main.c
gcc 1.c main.c -o main
变量名=变量值(递归的展开)
变量名:=变量值(简单的展开)
变量的引用: $(变量名 )
自动变量:
$@: 当前规则的目标文件
$<: 当前规则的第一个依赖文件
$^: 当前规则的所有依赖文件, 以逗号分隔
例子:
main:1.o main.o
gcc $^ -o $@
1.o:1.c
gcc -c $^ -o $@
main.o:main.c
gcc -c $^ -o $@
预定义变量:
AR : 库文件打包程序默认为 ar
AS: 汇编程序, 默认为 as
CC: c 编译器默认为 cc
CPP: c 预编译器, 默认为$(CC) –E
CXX: c++编译器, 默认为 g++
RM: 删除, 默认为 rm –f
ARFLAGS: 库选项, 无默认
ASFLAGS: 汇编选项, 无默认
CFLAGS: c 编译器选项, 无默认
CPPFLAGS: c 预编译器选项, 无默认
CXXFLAGS: c++ 编译器选项
例子:
obj:=1.o main.o
CC:=gcc
CFLAGS:=-Wall -I ./
main:$(obj)
$(CC) $(CFLAGS) $^ -o $@
1.o:1.c
$(CC) $(CFLAGS) -c $^ -o $@
main.o:main.c
两个函数:
使用的例子: $(wildcard *.c)
$(patsubst %.c,%.cpp,$(src))
把 $(src) 里面的字符串里面的 .c 换成 .cpp 其它的保留
例子:
src:=$(wildcard *.c)
obj:=$(patsubst %.c,%.o,$(src))
CC:=gcc
CFLAGS:=-Wall -I ./
main:$(obj)
$(CC) $(CFLAGS) $^ -o $@
%.o:%.c
$(CC) $(CFLAGS) -c $^ -o $@
.PHONY:clean
clean:
伪目标: 没有依赖文件的目标
写法:
.PHONY: 伪目标
CFLAGS:=-Wall -I ./
main:$(obj)
$(CC) $(CFLAGS) $^ -o $@
1.o:1.c
$(CC) $(CFLAGS) -c $^ -o $@
main.o:main.c
$(CC) $(CFLAGS) -c $^ -o $@
.PHONY:clean
clean:
rm -rf 1.o main.o main
把源文件编译成.o 文件: gcc -c 源文件 -o 目标文件
把.o 文件编译成可执行文件: gcc 目标文件 -o 执行文件gcc 常用的选项:
-c: 生成.o 文件
-o: 指定生成的名字
-I: 添加头文件搜索路径
-L: 添加库搜索路径
-Wall: 列出所有警告信息
例子:
1.c 1.h main.c, 把它们编译成一个可执行程序 main
在终端上编译:
gcc 1.c main.c -o main
Makefile 文件的编写:
2) makefile 的语法
目标
目标:依赖文件<tab>执行命令
备注:
目标----我们执行 make 想得到的东西
依赖文件----得到目标所需要的文件(用空格隔开)
执行命令---- 得目标所需要执行的命令
make 工具的执行过程:
在终端上输入: make--->在当前目录下找 Makefile 文件
----->以第一个目标为最终的目标开始执行
make 工程有什么好处?
1) 方便编译程序
2 ) 编译速度快
原因: make 一般的要求: 先把源文件编译成.o, 编译完以后再把所有的.o 文件进行链接。 Make 工具执行的时 候, 它会拿源文件和相应的.o 文件修改时间进行对比, 如果时间一样, 就不再对源文件进行编译!! 如
果.o 文件不存在 make 会往后找相应的规则, 生成相应的.o 文件。make 会往后找相应的规则, 生成相应 的.o 文件。
例子:main:1.c main.c
gcc 1.c main.c -o main
3.make 的变量
变量分为: 用户自定义变量, 预定义变量, 自动变量, 环境变量
变量名=变量值(递归的展开)
变量名:=变量值(简单的展开)
变量的引用: $(变量名 )
自动变量:
$@: 当前规则的目标文件
$<: 当前规则的第一个依赖文件
$^: 当前规则的所有依赖文件, 以逗号分隔
例子:
main:1.o main.o
gcc $^ -o $@
1.o:1.c
gcc -c $^ -o $@
main.o:main.c
gcc -c $^ -o $@
预定义变量:
AR : 库文件打包程序默认为 ar
AS: 汇编程序, 默认为 as
CC: c 编译器默认为 cc
CPP: c 预编译器, 默认为$(CC) –E
CXX: c++编译器, 默认为 g++
RM: 删除, 默认为 rm –f
ARFLAGS: 库选项, 无默认
ASFLAGS: 汇编选项, 无默认
CFLAGS: c 编译器选项, 无默认
CPPFLAGS: c 预编译器选项, 无默认
CXXFLAGS: c++ 编译器选项
例子:
obj:=1.o main.o
CC:=gcc
CFLAGS:=-Wall -I ./
main:$(obj)
$(CC) $(CFLAGS) $^ -o $@
1.o:1.c
$(CC) $(CFLAGS) -c $^ -o $@
main.o:main.c
$(CC) $(CFLAGS) -c $^ -o $@
两个函数:
目录下的文件名搜索函数
wildcard 文件名使用的例子: $(wildcard *.c)
字符串替换函数 patsubst
src:=$(wildcard *.c)$(patsubst %.c,%.cpp,$(src))
把 $(src) 里面的字符串里面的 .c 换成 .cpp 其它的保留
例子:
src:=$(wildcard *.c)
obj:=$(patsubst %.c,%.o,$(src))
CC:=gcc
CFLAGS:=-Wall -I ./
main:$(obj)
$(CC) $(CFLAGS) $^ -o $@
%.o:%.c
$(CC) $(CFLAGS) -c $^ -o $@
.PHONY:clean
clean:
rm -rf $(obj) main
伪目标: 没有依赖文件的目标
写法:
.PHONY: 伪目标
例子:
obj:=1.o main.o
CC:=gccCFLAGS:=-Wall -I ./
main:$(obj)
$(CC) $(CFLAGS) $^ -o $@
1.o:1.c
$(CC) $(CFLAGS) -c $^ -o $@
main.o:main.c
$(CC) $(CFLAGS) -c $^ -o $@
.PHONY:clean
clean:
rm -rf 1.o main.o main