makefile——小试牛刀

//a.h,包含头文件stdio.h,并且定义一个函数print
#include<stdio.h>
void print();

//b.c,包含头文件a.h,然后就可以写print函数的内容了
#include"a.h"
void print(){
printf("who are you\n");
}

//c.c,包含头文件a.h,调用print函数
#include"a.h"
int main(){
print();
return 0;
}

下面是Makefile 固定命名,记住这些文件全部在同一文件夹下,全部编写完成后,执行make命令就会自动执行Makefile了,


hello:c.o b.o   //其中hello是目标文件,c.o和b.o是依赖文件,需要这两个文件才能生成hello,因为现在还没有c.o文件,所以跳到c.o:c.c a.h那里,然后执行gcc -c c.c 执行完成后又返回该条语句,发现也没有b.o,所以跳到b.o:b.c a.h
    gcc -o hello c.o b.o  //这个是shell命令
c.o:c.c a.h
    gcc -c c.c    //其中gcc -c c.c是指编译生产c.o(改成gcc -o c.o c.c会报错)
b.o:b.c a.h
    gcc -c b.c
clean:      //执行make clean会执行下面的语句
    rm hello c.o b.o

执行效果如下

[root@bogon bp]# ls
a.h  b.c  c.c  Makefile
[root@bogon bp]# make
gcc -c c.c 
gcc -c b.c
gcc -o hello c.o b.o
[root@bogon bp]# ls
a.h  b.c  b.o  c.c  c.o  hello  Makefile
[root@bogon bp]# ./hello
who are you

改进后的方法,只需要修改Makefile

[root@bogon bp]# cat Makefile 
objects=c.o b.o    相当于C语言的宏定义变量
hello:c.o b.o
    gcc -o hello $(objects)
c.o:c.c a.h
    gcc -c c.c 
b.o:b.c a.h
    gcc -c b.c
clean:
    rm hello $(objects)

我们还能更精简这个过程,也是只修改Makefile

[root@bogon bp]# make
cc    -c -o c.o c.c
cc    -c -o b.o b.c
gcc -o hello c.o b.o
[root@bogon bp]# ls
a.h  b.c  b.o  c.c  c.o  hello  Makefile
[root@bogon bp]# ./hello
who are you
[root@bogon bp]# cat Makefile 
objects=c.o b.o
hello:c.o b.o
    gcc -o hello $(objects)
$(bojects):a.h  因为c.o和b.o都依赖a.h
c.o:c.c     可以省略掉gcc
b.o:b.c
clean:
    rm hello $(objects)
[root@bogon bp]# 

上面是我自己总结写的,

进行内核编译的时候make会多两个选项,-C和-M.

其中-C $(KDIR) 指明跳转到内核源码目录下读取那里的Makefile;M=$(PWD) 表明然后返回到当前目录继续读入、执行当前的Makefile。