韦东山嵌入式第一期学习笔记DAY_6——9_5_Makefile的引入及规则

作者:GWD 时间:2019.7.6

一、课程内容:
摘要:第一点:本节课写了一个代码,代码功能是新建两个文件,a.c和b.c在a.c中调用b.c中的printf函数,用Makefile连接a.c和b.c;第二点:讲解了Makefile的一些规则。
1、
a.c

#include "stdio.h"
int main(void)
{
fun_b();
return 0;
}

b.c

#include "stdio.h"
void fun_b(void)
{
	printf("This is B\n");
}

2、问:若不用Makefile怎么连接这两个.c文件?
答:gcc -o test a.c b.c,这样做的缺点是,若更改了a.c或者b.c就需要所有文件都重新编译一次,linux源码中有几十甚至更多代码,这样显然是不行的。引入Makefile
韦东山嵌入式第一期学习笔记DAY_6——9_5_Makefile的引入及规则_第1张图片
韦东山嵌入式第一期学习笔记DAY_6——9_5_Makefile的引入及规则_第2张图片
3、Makefile的引入及规则
1)、使用keil, mdk, avr等工具开发程序时点点鼠标就可以编译了,
它的内部机制是什么?它怎么组织管理程序?怎么决定编译哪一个文件?
2)、问:Makefile的核心?
答:规则是其核心。
目标 : 依赖1 依赖2 …
[TAB]命令
当"目标文件"不存在, 或某个依赖文件比目标文件"新",则: 执行"命令"
3)、分析课程中的Makefile文件
韦东山嵌入式第一期学习笔记DAY_6——9_5_Makefile的引入及规则_第3张图片

test  : a.o b.o
	gcc -o test a.o b.o
a.o : a.c
	gcc -c -o a.o a.c
b.o : b.c
	gcc -c -o b.o b.c

(1)、在命令行输入make之后,编译器会在文件夹中寻找Makefile文件,默认生成第一个目标test,Test是目标,依赖两个.o
但是test又依赖a.o和b.o所以继续向下寻找,a.o又依赖于a.c当a.c比a.o新的时候重新生成a.o;当修改a.c后,make后发现a.c比a.o新所以重新生成a.o;b.o不用管。所以只执行了两条代码。
(2)、“:”读作依赖,某个目标的生成依赖于某些依赖文件。
二、学习要点:
注:ubuntu环境下,在命令行输入ctrl+l清屏
1、在Linux中使用make命令来编译程序;而make命令所执行的动作依赖于Makefile文件。Make命令根据文件更新的时间戳来决定哪些文件需要重新编译。
2、
如下图格式中,目标通常是要生成的文件的名称,可以使可执行文件,也可以是一个执行的动作名称,比如clean;命令是依赖文件生产目标时执行的动作。每个命令行前面必须是一个TAB,即命令行第一个字符是TAB,这里很容出错。
在这里插入图片描述

三、代码:(无)

你可能感兴趣的:(ARM裸机,韦东山第一期)