make 学习体会(一)

简介:
在对makefile进行了部分学习后,感觉到还是多看看简短的例子比较好。

发现下面这个网站讲得很好:

http://www.cs.colby.edu/maxwell/courses/tutorials/maketutor/

hellomake.c:

复制代码
#include 
int main() {
  // call a function in another file
  myPrintHelloMake();

  return(0);
}
复制代码
hellofunc.c:

复制代码
#include 
#include 

void myPrintHelloMake(void) {
  printf("Hello makefiles!\n");
  return;
}
复制代码
hellomake.h:

/*
example include file
*/
void myPrintHelloMake(void);
第一个 makefile的例子:

hellomake: hellomake.c hellofunc.c
     gcc -o hellomake hellomake.c hellofunc.c -I.
hellomake 是规则名;它的前提条件是:hellomake.c 和 hellofunc.c。

在此规则中,我们要执行的片段是: gcc -o hellomake hellomake.c hellofunc.c -I

第二个 makefile的例子:

CC=gcc
CFLAGS=-I.

hellomake: hellomake.o hellofunc.o
     $(CC) -o hellomake hellomake.o hellofunc.o -I.
此处定义了 变量 cc 和 CFLAGS , 这也是很多 makefile中很常见的两个变量。

此时,规则 hellomake 依赖于两个目标文件 hellomake.o 和 hellofunc.o ,

而且这里有一个隐含的依赖关系:

hellomake.o 来自于对 hellomake.c 的编译

hellofunc.o 来自于 对 hellofunc.c 的编译

由于为了生成 hellomake,需要 hellomake.o 和 hellofunc.o ,

就意味着实际上需要 hellomake.c 和 hellofunc.c。

$(CC) 就代表了 gcc 命令,此处实际上还尚未使用 CFLAGS 变量。

 

第三个 makefile例子:

复制代码
CC=gcc
CFLAGS=-I.
DEPS = hellomake.h

%.o: %.c $(DEPS)
    $(CC) -c -o $@ $< $(CFLAGS)

hellomake: hellomake.o hellofunc.o 
    gcc -o hellomake hellomake.o hellofunc.o -I.
复制代码
%.o: 规则表明:每一个 .o 文件,都是依赖于 同名的 .c 文件,和 DEPS 所定义的头文件。

具体为了生成此 .o 文件,需要进行编译动作:

$(CC) -c -o $@ $< $(CFLAGS)

其中 $(CC) 和 -c -o 都不用解释了。

$@表示的就是 冒号左边的内容,即某个.o 文件。

$<表示的就是 冒号右边的第一个参数,即此同名的.c 文件。

$(CFLAGS) 在这里就是 -I。

 

第四个 makefile例子:

复制代码
CC=gcc
CFLAGS=-I.
DEPS = hellomake.h
OBJ = hellomake.o hellofunc.o 

%.o: %.c $(DEPS)
    $(CC) -c -o $@ $< $(CFLAGS)

hellomake: $(OBJ)
    gcc -o $@ $^ $(CFLAGS)
复制代码
同上个例子相比,它又定义两个 OBJ变量。

hellomake 依赖于 OBJ变量所指代的目标文件,

gcc -o $@ $^ $(CFLAGS) 中,其他的都不用再解释了。

$^ 是冒号右边的值,这里就是 $(OBJ),也就是 hellomake.o, hellofunc.o。

 

第五个 makefile例子:

复制代码
IDIR =../include
CC=gcc
CFLAGS=-I$(IDIR)

ODIR=obj
LDIR =../lib

LIBS=-lm

_DEPS = hellomake.h
DEPS = $(patsubst %,$(IDIR)/%,$(_DEPS))

_OBJ = hellomake.o hellofunc.o 
OBJ = $(patsubst %,$(ODIR)/%,$(_OBJ))


$(ODIR)/%.o: %.c $(DEPS)
    $(CC) -c -o $@ $< $(CFLAGS)

hellomake: $(OBJ)
    gcc -o $@ $^ $(CFLAGS) $(LIBS)

.PHONY: clean

clean:
    rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~ 
复制代码
这里面 IDIR,LDIR,ODIR 分别指定了 头文件/库文件/输出目标文件的目录。

来看这一句:

DEPS = $(patsubst %,$(IDIR)/%,$(_DEPS))
patsubst 是一个 函数,它会把所有 % 所代表的文件字符串,改变为 头文件目录下的 文件字符串。

第三个参数 $(_DEPS)指明了这个 函数的作用范围。

OBJ = $(patsubst %,$(ODIR)/%,$(_OBJ)) 的作法与此类似。

其他的,也没有什么可以说的了,但是 这里有一个伪规则 clean。它是没有前提条件的。

rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~ 中,

*~ , 我猜测代表的是 所有没有扩展名的文件。core 指代的是程序出错时生成的 core 文件。

标签: Makefile, example


本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/09/17/2688165.html,如需转载请自行联系原作者
目录
相关文章
|
5月前
|
编译器 C语言
针对make工具和Makefile文件的学习心得
【8月更文挑战第24天】本文分享了关于 make 工具和 Makefile 文件的学习心得。make 工具与 Makefile 在软件开发特别是大型项目中扮演着重要角色,能自动化构建流程并提升开发效率。文章首先强调了了解 make 和 Makefile 重要性的必要性,并详细解析了 Makefile 的基本结构:包括目标、依赖和命令的定义;通过变量简化命令与依赖;以及伪目标的使用等。接着,文中介绍了几个关键的 Makefile 编写技巧:如何合理组织依赖关系,有效利用变量和宏,灵活运用自动变量,以及添加清晰的注释等。
|
6月前
|
自然语言处理 Linux C++
make和Cmake都有什么区别?(内附使用详解)
make: 是一个构建工具,它的任务是读取 Makefile 文件,并基于这些文件中的指令执行具体的构建操作。Makefile 文件包含了如何构建项目的规则,make 负责解析这些规则并执行必要的命令来编译和链接源代码,生成可执行文件或库。 CMake: 是一个构建系统生成器。它并不直接进行编译或链接,而是根据项目中 CMakeLists.txt 文件的内容生成一个或多个构建系统的描述文件(如 Makefile 或 Visual Studio 解决方案)。CMake 提供了一种更高级、更抽象的方式来描述构建过程,这使得它能够跨平台地生成各种构建系统。
542 0
|
7月前
|
存储 小程序 程序员
Essential C++ 第1章 C++编程基础 (笔记)
Essential C++ 第1章 C++编程基础 (笔记)
|
8月前
|
JSON 资源调度 JavaScript
【源码共读】编程式安装依赖 install-pkg
【源码共读】编程式安装依赖 install-pkg
104 2
|
并行计算 Ubuntu 编译器
现代cmake--阅读笔记
现代cmake--阅读笔记
290 0
现代cmake--阅读笔记2
现代cmake--阅读笔记2
226 0

热门文章

最新文章