Makefile的制作

Posted 小禾先生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Makefile的制作相关的知识,希望对你有一定的参考价值。

一个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中,makefile定义系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就想一个Shell脚本一样,其中也可以执操作系统的命令。

 

Linux环境下的程序员如果不会使用GUN make来构建和管理自己的工程,应该不能算是一个合格的专业程序员。在Linux(Unix)环境下使用GUN的make工具能够比较容易的构建一个属于你自己的工程,整个工程的编译只需要一个命令就可以完成编译、连接以至于最后的执行。不过这需要我们投入一些时间去完成一个或者多个称之为makefile文件的编写。

 

所要完成的makefile文件描述了整个工程的编译、连接等规则。其中包括:工程的哪些源文件需要编译、需要创建哪些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。尽管看起来可能是很复杂的事情,但是为了工程编写makefile的好处是能够使用一行命令来完成“自动化编译”,一旦提供一个正确的makefile。编译整个工程你嗦要做的唯一的一件事就是在shell提示符下输入make命令,这个工程完全自动编译,极大地提高了效率。

 

Makefile结构

#表示注释

 

变量定义

VAR=test  定义变量VAR,强制付志伟test

VAR+=app  在VAR之前定义的值后面再追加app这个值

VAR?=testapp  如果之前VAR没有被定义,则定义并使用testapp,否则使用之前的值

 

第一条目标为总的目标

依赖可以是文件(目录)或为其他目标

动作可以是Linux命令,动作的哪一行第一个字符必须是以TAB键补齐的

target:  depend1  depend2  depend3 ......

[TAB] action1

[TAB] action2

target: 

[TAB] action1

[TAB] action2

 

makefile的使用

make找makefile或者Makefile文件执行总的目标

make clean  执行makefile文件中的clean目标

make -C directory  进入到directory文件夹中去执行总的目标

make clean -c directory  进入到directory文件夹中去执行clean目标

make -f comm_makefile  通过-f选项指定一个makefile文件

make VAR=value  给makefile传一个参数VAR,其值为value

 

案例:

分别创建vendor1与vendor2两个文件夹,在这两个文件夹中放两个函数
[[email protected] library]$ mkdir vendor1
[[email protected] library]$ mkdir vendor2
[[email protected] library]$ cd vendor1

[[email protected] vendor1]$ vim crypto.c

#include <stdio.h>

void crypto(void)
{
    printf("Start crypt...");

    return ;
}

[[email protected] vendor1]$ vim crypto.h

#ifndef _CRYPTO_H_
#define _CRYPTO_H_

void crypto(void);

#endif

[[email protected] vendor1]$ vim makefile

LIB_NAME=vendor1

all: shared  static
    rm -f *.o

shared:
    gcc -shared -fpic -o lib${LIB_NAME}.so *.c

static:
    gcc -c *.c
    ar -rcs lib${LIB_NAME}.a *.o

clean:
    rm -f *.a *.so
    rm -f *.o

install:
    cp lib${LIB_NAME}.* ../libs

[[email protected] vendor1]$ cd ../vendor2

[[email protected] vendor2]$ vim func.c

#include <stdio.h>

void func(void)
{
    printf("Start func...");

    return ;
}

[[email protected] vendor2]$ vim func.h

#ifndef _FUNC_H_
#define _FUNC_H_

void func(void);

#endif

[[email protected] vendor2]$ vim makefile

LIB_NAME=vendor2

all: shared  static
    rm -f *.o

shared:
    gcc -shared -fpic -o lib${LIB_NAME}.so *.c

static:
    gcc -c *.c
    ar -rcs lib${LIB_NAME}.a *.o

clean:
    rm -f *.a *.so
    rm -f *.o

install:
    cp lib${LIB_NAME}.* ../libs

[[email protected] vendor2]$ cd ..

[[email protected] library]$ vim main.c

#include "crypto.h"
#include "func.h"

int main(void)
{
    crypto();
    func();

    return 0;
}

[[email protected] library]$ vim makefile

APP_NAME?=app

all: lib_vendor1  lib_vendor2
    gcc -static main.c -Ivendor1 -Ivendor2 -o ${APP_NAME} -Lvendor1 -Lvendor2 -lvendor1 -lvendor2

lib_vendor1:
    make -C vendor1

lib_vendor2:
    make -C vendor2

[[email protected] library]$ ls
main.c  makefile  vendor1  vendor2

[[email protected] library]$ make
make -C vendor1
make[1]: Entering directory `/home/xiaohexiansheng/cc/library/vendor1‘
gcc -shared -fpic -o libvendor1.so *.c
gcc -c *.c
ar -rcs libvendor1.a *.o
rm -f *.o
make[1]: Leaving directory `/home/xiaohexiansheng/cc/library/vendor1‘
make -C vendor2
make[1]: Entering directory `/home/xiaohexiansheng/cc/library/vendor2‘
gcc -shared -fpic -o libvendor2.so *.c
gcc -c *.c
ar -rcs libvendor2.a *.o
rm -f *.o
make[1]: Leaving directory `/home/xiaohexiansheng/cc/library/vendor2‘
gcc main.c -Ivendor1 -Ivendor2 -o app -Lvendor1 -Lvendor2 -lvendor1 -lvendor2
[[email protected] library]$ ls
app  main.c  makefile  vendor1  vendor2

以上是关于Makefile的制作的主要内容,如果未能解决你的问题,请参考以下文章

Makefile

是否有一种可移植的方式在 Makefile 中制作可移植的可选依赖项?

makefile中的Cflags用法

python 用于在终端中运行的sublime text 3的简单代码片段制作工具

Makefile的制作

Makefile:没有规则来制作目标。停止