对 makefile 中 .SUFFIXES 的学习体会

简介:

当前目录中存在 gao.g 文件(其实际内容是一个简单的C语言程序)

先是用如下的例子来看:例子一

复制代码
.SUFFIXES:
.SUFFIXES:  .g  .o

LIBS=gao.o

all: $(LIBS)

%.o:%g
    @echo "in %.o:%g"
复制代码

运行结果是: no rule to make target gao.o...

也就是说 .SUFFIXES 和 %.o:%g 模式规则一起使用没有效果。

 

再看看如下的例子:把.SUFFIXES 去掉看看,例子二

LIBS=gao.o

all: $(LIBS)

%.o:%g
    @echo "in %.o:%g"

运行结果仍然是:no rule to make target gao.o...

再看看如下的例子: 用传统格式 .g.o, 例子三

复制代码

LIBS=gao.o

all: $(LIBS)

.g.o:
    @echo "in .g.o"
复制代码

结果仍然是: no rule to make target gao.o...

再看看如下的例子,在前面例子的基础上,加入 .SUFFIXES

复制代码
.SUFFIXES:
.SUFFIXES:  .g  .o

LIBS=gao.o
all: $(LIBS)

.g.o:
    @echo "in .g.o"
复制代码

结果是,in  .g.o

小结一下:.SUFFIXES 和 .a.b 格式可以相互配合, 和 %b:%a 是无法配合的。

再看 .SUFFIXES 和 .c .o 的关系:

把 gao.g 改名为 gao.c 。看下面的例子:

LIBS=gao.o
all:$(LIBS)

.c.o:
    @echo "in .c.o"

运行结果为 in .c.o,也就是说对于.c 文件编译成 .o 文件,没有 .SUFFIXES 也可以。

再改为模式规则格式:

LIBS=gao.o
all:$(LIBS)

%o:%c
    @echo "in %o:%c"

运行结果为 in %o:%c ,模式规则也不依赖于 .SUFFIXES。

下面的略为跑题。当然,make 对 .c 文件 .o 文件都有自己的处理,比如什么都不写:

只有如下两句:

LIBS=gao.o
all: $(LIBS)

运行make 后的结果会怎么样:

cc    -c  -o  gao.o  gao.c

得到了一个 gao.o的文件,但是这个只是一个编译好但尚未链接的程序。

既使chmod 777 gao.o

再运行  ./gao.o 也会得到提示:bash unable to run binary file.

要想运行,还需要手工执行链接动作 :cc  -o  my.o  gao.o。

如果没有makefile ,单纯执行,则是不带-c选项: cc -o gao.o gao.c  ,可以得到可执行文件gao.o





本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/09/21/2696482.html,如需转载请自行联系原作者

目录
相关文章
|
5月前
|
编译器 C语言
针对make工具和Makefile文件的学习心得
【8月更文挑战第24天】本文分享了关于 make 工具和 Makefile 文件的学习心得。make 工具与 Makefile 在软件开发特别是大型项目中扮演着重要角色,能自动化构建流程并提升开发效率。文章首先强调了了解 make 和 Makefile 重要性的必要性,并详细解析了 Makefile 的基本结构:包括目标、依赖和命令的定义;通过变量简化命令与依赖;以及伪目标的使用等。接着,文中介绍了几个关键的 Makefile 编写技巧:如何合理组织依赖关系,有效利用变量和宏,灵活运用自动变量,以及添加清晰的注释等。
|
8月前
|
Linux Python
一文教你学会Makefile脚本的简单应用
一文教你学会Makefile脚本的简单应用
80 0
|
存储 运维 编译器
Linux运维:makefile
Linux运维:makefile
115 0
|
程序员 编译器 Shell
一步步写属于自己的makefile
一步步写属于自己的makefile
|
NoSQL Shell Linux
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界(三)
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界
285 0
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界(三)
|
Shell Linux 开发工具
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界(一)
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界
549 0
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界(一)
|
自然语言处理 算法 NoSQL
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界(二)
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界
229 0
【六、深度解析Makefile】工程文件编译链接的“规则制定者”:带你走进 makefile 的世界(二)
玩转Makefile | 企业项目Makefile实例
玩转Makefile | 企业项目Makefile实例
264 0
玩转Makefile | 企业项目Makefile实例