赞
踩
一、Makefile介绍
个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为 makefile就像一个Shell脚本一样,也可以执行操作系统的命令。
二、GCC编译流程 – C语言编译
1 . 预处理阶段 gcc -E -o hello.i hello.c 这句命令 其中 hello.i 是 hello.c 预编译处理后的文件,预处理之后,会把hello.h 的内容插入到 hello.i 文件中
2 . 编译阶段 GCC 首先要检查代码的规范性,是否有语法错误等,以确定代码实际要做的工作,在检查无误后,就开始把代码翻译成汇编语言。其中,GCC 的选项 gcc -S hello.c -o hello.s ( -S 不能小写) 其中hello.s 就是汇编语言原始程序了
3 . 汇编阶段 汇编阶段是把编译阶段生成的 .s 文件生成目标文件,在此使用选项 -c 就可以看到汇编代码已转换为 .o 的二进制代码 gcc -c hello.c -o hello.o
4 . 链接阶段 这里涉及一个重要的概念: 函数库 比如你是用到了 “printf” 函数,但是程序中并没有这个函数的实现,同时 “stdio.h” 中也只有该函数的声明,并没有函数的定义,所以有一个问题,它是怎么实现的呢? 说明,系统把这些函数实现都已经放入名为 “libc.so.6” 的库文件中去了。在没有特别指定时,GCC会到系统默认的搜索路径 “/usr/lib” 下进行查找,这样就能实现函数 “printf” 了,而这也就是链接的作用。 gcc hello.o -o hello ./hello 这样一个编译过程就完成了
三、make 工程管理器
make 是一个自动编译管理器,能够根据文件时间戳自动发现更新过的文件从而减少编译的工作量。(在Makefile 中的每一个command 前都需要一个“Tab”符,否则在运行make命令时会出错)其中command 是创建每个目标体时需要运行的命令 例如:有两个文件分别为 “hello.c” “hello.h” , 希望创建的目标为 “hello.o” , 执行的命令为GCC编译指令 “gcc -c hello.c” ,那么,对应的Makefile 就可以写为以下形式。 hello.o: hello.c hello.h gcc -c hello.c -o hello.o上面代码只是加深题解,因为它过于简单。在实际中使用的Makefile往往包含很多命令,一个项目也会包含多个Makefile。 AR 库文件维护程序的名称,默认值arAS 汇编程序的名称,默认值asCC C编译器的名称,默认值为cc
CPP C预编译器的名称,默认值为$(CC) -ECXX C++编译器的名称,默认值为g++FC
FORTRAN 编译器的名称,默认值 f77RM 文件删除程序的名称,默认值为rm-f
ARFLAGS 库文件维护程序的选项,无默认值
ASFLAGS 汇编程序的选项,无默认值 CFLAGS C编译器的选项,无默认值CPPFLAGS C预编译器的选项,无默认值CXXFLAGS C++编译器的选项,无默认值FFLAGS FORTRAN编译器的选项,无默认值
四、示例
src := $(shell ls *.c) /把当前目录下所有c源代码赋给变量src/
objs :=
(
p
a
t
s
u
b
s
t
(patsubst %.c,%.o,
(patsubst(src)) /调用makefile 中的函数patsubst, 用.o文件代替.c文件/
test: $(objs)
gcc -o $@ $^
%.o:%.c
gcc -c -o $@ $<
clean:
rm -f test *.o
上述Makefile中的“
@
"
,
"
@", "
@","^", “$<” 称为自动变量。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。