linux makefile面试题,linux下gcc下makefile文件的编写

2015-10-14 06:30:02

阅读( 157 )

假设我们有下面这样的一个程序,源代码如下:

/* main.c */

#include “mytool1.h”

#include “mytool2.h”

int main(int argc,char **argv)

{

mytool1_print(“hello”);

mytool2_print(“hello”);

}

/* mytool1.h */

#ifndef _MYTOOL_1_H

#define _MYTOOL_1_H

void mytool1_print(char *print_str);

#endif

/* mytool1.c */

#include “mytool1.h”

void mytool1_print(char *print_str)

{

printf(“This is mytool1 print %s\n”,print_str);

}

/* mytool2.h */

#ifndef _MYTOOL_2_H

#define _MYTOOL_2_H

void mytool2_print(char *print_str);

#endif

/* mytool2.c */

#include “mytool2.h”

void mytool2_print(char *print_str)

{

printf(“This is mytool2 print %s\n”,print_str);

}

当然由于这个程序是很短的我们可以这样来编译

gcc -c main.c

gcc -c mytool1.c

gcc -c mytool2.c

gcc -o main main.o mytool1.o mytool2.o

这样的话我们也可以产生 main 程序,而且也不时很麻烦.但是如果我们考虑一下如果有

一天我们修改了其中的一个文件(比如说 mytool1.c)那么我们难道还要重新输入上面的命令?

也许你会说,这个很容易解决啊,我写一个 SHELL 脚本,让她帮我去完成不就可以了.是的对

于这个程序来说,是可以起到作用的,但是当我们把事情想的更复杂一点,如果我们的程序有

几百个源程序的时候,难道也要编译器重新一个一个的去编译?

为此,聪明的程序员们想出了一个很好的工具来做这件事情,这就是 make.我们只要执行

以下 make,就可以把上面的问题解决掉.在我们执行 make 之前,我们要先编写一个非常重要的

文件.–Makefile.对于上面的那个程序来说,可能的一个 Makefile 的文件是:

# 这是上面那个程序的 Makefile 文件

main:main.o mytool1.o mytool2.o

gcc -o main main.o mytool1.o mytool2.o

main.o:main.c mytool1.h mytool2.h

gcc -c main.c

mytool1.o:mytool1.c mytool1.h

gcc -c mytool1.c

mytool2.o:mytool2.c mytool2.h

gcc -c mytool2.c

有了这个 Makefile 文件,不过我们什么时候修改了源程序当中的什么文件,我们只要执行

make 命令,我们的编译器都只会去编译和我们修改的文件有关的文件,其它的文件她连理

都不想去理的。

下面我们学习 Makefile 是如何编写的。

在 Makefile 中也#开始的行都是注释行.Makefile 中最重要的是描述文件的依赖关系的说

明.一般的格式是:

target: components

TAB rule

第一行表示的是依赖关系.第二行是规则.

比如说我们上面的那个 Makefile 文件的第二行

main:main.o mytool1.o mytool2.o

表示我们的目标(target)main 的依赖对象(components)是 main.o mytool1.o mytool2.o

当倚赖的对象在目标修改后修改的话,就要去执行规则一行所指定的命令.就象我们的上

面那个 Makefile 第三行所说的一样要执行 gcc -o main main.o mytool1.o mytool2.o

注意规则一行中的 TAB表示那里是一个 TAB 键

Makefile 有三个非常有用的变量.分别是$@,$^,$

$@–目标文件,$^–所有的依赖文件,$

如果我们使用上面三个变量,那么我们可以简化我们的 Makefile 文件为:

# 这是简化后的 Makefile

main:main.o mytool1.o mytool2.o

gcc -o $@ $^

main.o:main.c mytool1.h mytool2.h

gcc -c $<

mytool1.o:mytool1.c mytool1.h

gcc -c $<

mytool2.o:mytool2.c mytool2.h

gcc -c $<

经过简化后我们的 Makefile 是简单了一点,不过人们有时候还想简单一点.这里我们学习

一个 Makefile 的缺省规则

..c.o:

gcc -c $<

这个规则表示所有的 .o文件都是依赖与相应的.c 文件的.例如 mytool.o依赖于 mytool.c

这样 Makefile 还可以变为:

# 这是再一次简化后的 Makefile

main:main.o mytool1.o mytool2.o

gcc -o $@ $^

..c.o:

gcc -c $<

好了,我们的 Makefile 也差不多了,如果想知道更多的关于 Makefile 规则可以查看相应的

文档。

分享给朋友:

亲~ 如果您有更好的答案 可在评论区发表您独到的见解。

您想查看更多的信息:

面试题

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值