linux源文件编译工具Makefile编译流程

一、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中的“ @ " , " @", " @","^", “$<” 称为自动变量。

你可能感兴趣的:(linux,arm)