《跟我一起学makefile》学习笔记(一)

    最近在学习朱有鹏老师的嵌入式课程,讲到了makefile,朱老师推荐了陈皓老师的《跟我一起学makefile》。自己对makefile一知半解,决定跟着文档,系统地学习一下,现记录如下(对应文档的p1-p9):

第一部分 概述
    makefile,管理大型工程的源码,定义一系列规则。
指定哪些文件先编译、后编译、重新编译。
    文件依赖性
第二部分 关于程序的编译和链接
    编译(compile):把源文件变成中间代码文件(win下是.obj;linux下是.o(Object File))
    需要:语法正确,函数与变量的声明正确,告诉编译器头文件的所在位置(头文件中应该只是声
明,而定义应该放在 C/C++文件中)。
    一般来说,每个源文件对应一个中间目标文件
    
    链接(link):把大量的.o文件,合成执行文件
    链接函数和全局变量,使用这些中间目标文件(O 文件或是OBJ文件)来链接应用程序。
    不管函数所在的源文件,只管函数的中间目标文件 。
    由于源文件太多,编译生成的中间目标文件太多,在链接时需要明显地指出中间目标文件名,这对于编译很不方便。
    所以,给中间目标文件打个包,在 Windows 下叫“库文件”(Library  File),也就是 .lib 文件,
    在 UNIX下,是 Archive File,也就是 .a 文件。
第三部分 Makefile介绍
一、Makefile的规则
target ... : preprequisites ...
    command
    ...
    ...
说明:
target:目标文件,Object File、执行文件、标签
preprequisites:生成target依赖的文件或目标
command:任意shell命令
    文件的依赖关系,prerequisites中的文件比target新,就执行command
二、一个示例
    8个C文件、3个头文件
edit:main.o kbd.o command.o display.o \
insert.o search.o files.o utils.o
    gcc -o edit main.o kbd.o command.o display.o \
insert.o files.o utils.o

main.o:main.c defs.h
    gcc -c main.c
kbd.o:kbd.c defs.h command.h
    gcc -c kbd.c
command.o:command.c defs.h command.h
    gcc -c command.c
display.o:display.c defs.h buffer.h
    gcc -c display.c
insert.o:insert.c defs.h buffer.h
    gcc -c insert.c
search.o:search.c defs.h buffer.h
    gcc -c search.c
files.o:files.c defs.h buffer.h command.h
    gcc -c files.c
utils.o:utils.c defs.h
    gcc -c utils.c
clean:
    rm edit main.o kbd.o command.o display \
    insert.o search.o files.o utils.o
说明:\ 表示换行
makefile里写程序的打包、备份等
三、make是如何工作的
1、在当前目录下找名字叫“Makefile”或“makefile”的文件。  
2、找文件中的第一个目标文件(target) ,在上面的例子中是“edit”,并把这个文件作为最终的目标文件。  
3、如果edit文件不存在, 或是edit所依赖的后面的 .o 文件的文件修改时间要比edit
这个文件新,那么,执行后面所定义的命令生成 edit 。  
4、如果 edit所依赖的.o文件也存在,那么 make 会在当前文件中找目标为.o 文件的依
赖性,如果找到则再根据那一个规则生成.o 文件。 (这有点像一个堆栈的过程)  
5、make 会生成 .o 文件, 然后再用 .o 文件生命 make的终极任务,也就是执行文件 edit了。 

你可能感兴趣的:(makefile,嵌入式)