Makefile - 学习笔记

–[[
一些小命令:
1.如果要指定特定的 Makefile,你 可 以 使 用 make 的 “ -f” 和 “ --file” 参 数 , 如 : make -f Make.Linux 或 make --file Make.AIX。
2.make 支持 三各通配符:“*”,“?”和“[…]”。波浪号(“~”)表示当前 用户的$HOME 目录
–]]

1、关于编译和连接:

  • 编译时:编译器主要检测的是语法的正确,函数与变量的声明的正确。编译成功后会生成一个中间目标文件(o文件或obj文件)
  • 由于源文件太多,我们要给中间目标文件打个包,在 Windows 下这种包叫“库文件”(LibraryFile),也就是 .lib 文件,在 UNIX 下,是 Archive File,也就是 .a 文件。
  • 连接:链接器并不管函数所在的源文件,只管函 数的中间目标文件(Object File)

2、源文件首先会生成中间目标文件,再由中间目标文件生成执行文件(连接器)

  • 如果函数未被声明,编译器会 给出一个警告,但可以生成 Object File
  • 如果找不到,那到就会报链接错误码(Linker Error),在 VC 下,这种错误一般是:Link 2001 错误,意思说是说,链接器未能找到函数的实现
  • 你 需要指定函数的 Object File.

3、关于Makefile:

  • 一般用makefile进行文件的批处理编译和连接到生成文件(编译和连接程序)简单的说makefile就是make执行的文件,将代码变成可行性文件的过程叫做编译,组成一些列文件的编译加做构建,Make是GUN提供的构建工具,而使用Make,就需要会使用makefile编写

4、Makefile规则:

target ... : prerequisites ...
command
...
...
  • target 也就是一个目标文件 ,可以是 Object File,也可以是执行文件 还可以是一个标 签(Label)
  • prerequisites 就是,要生成那个 target 所需要的文件或是目标。
  • command 也就是 make 需要执行的命令。(任意的 Shell 命令)
  • 反斜杠(\)是换行符的意思

例如:

edit:test.o 			
	gcc -o edit test.o
test.o:test.c
	gcc -c test.c
clean:
	rm edit *.o
  • 先定义好依赖关系,依赖关系的实质上就是说 明了目标文件是由哪些文件生成的,换言之,目标文件是哪些文件更新的
  • 定义好依赖关系后,后续的那一行定义了如何生成目标文件的操作系统命令
  • make clean:删除执行文件和所有的中间目标文件
  • .PHONY : clean :.PHONY 意思表示 clean 是一个“伪目标”,。而在 rm 命令前面加了一个小 减号的意思就是,也许某些文件出现问题,但不要管,继续做后面的事
  • 关于clean:clean 不是一个文件,它只不过是一个动作名字。那么 make 就不会自动去找文件的依赖性,也就不会自动执行其后所定义的命令。

make是如何工作的:

1.make 会在当前目录下找名字叫“Makefile”或“makefile”的文件。
2.如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到 “edit”这个文件,并把这个文件作为最终的目标文件。
3.如果 edit 文件不存在,或是 edit 所依赖的后面的 .o 文件的文件修改时间要比 edit 这 个文件新,那么,他就会执行后面所定义的命令来生成 edit 这个文件
4.如果 edit 所依赖的.o 文件也存在,那么 make 会在当前文件中找目标为.o 文件的依赖性,如果找到则再根据那一个规则生成.o 文件。
5.于是 make 会生成 .o 文件,然后再用 .o 文件生成可执行文件 edit

  • make 会一层又一层地去找文件的依赖关系,直到最终编 译出第一个目标文件。
  • 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到, 那么 make 就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make 不会处理。make 只管文件的依赖性

5、makefile 中使用变量

  • 定义一个变量:变量名 = 变量值
  • 调用这个变量:$(objects)
    例如:
objects = test.o
edit:$(objects)
	gcc -o edit test.o
test.o:test.c
	gcc -c test.c
clean:
	rm edit *.o

6、让 make 自动推导

只要 make 看到一个[.o]文件,它就会自动的把[.c]文件加在依赖关系中
如果 make 找 到一个 whatever.o ,那么 whatever.c ,就会是 whatever.o 的依赖文件
例如:

objects = test.o
edit:$(objects)
	gcc -o edit test.o
test.o:
	gcc -c test.c
clean:
	rm edit *.o

7.引用其它的 Makefile

在 Makefile 使用 include 关键字可以把别的 Makefile 包含进来 - include -
例如:include foo.make a.mk b.mk c.mk e.mk f.mk

8.环境变量 MAKEFILES

  • 如果你的当前环境中定义了环境变量 MAKEFILES,那么,make 会把这个变量中的值 做一个类似于 include 的动作 ,这个变量中的值是其它的 Makefile,用空格分隔。只是,它和 include 不同的是,从这个环境变中引入的 Makefile 的“目标”不会起作用,如果 环境变量中定义的文件发现错误,make 也会不理。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值