Makefile简介及相关用法

Makefilede 介绍:

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

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

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



Makefile的结构:

#  #表示注释


#变量定义
VAR=test   定义变量VAR,强制赋值为app  
VAR+=app   在VAR之前定义的值后面再追加app这个值
VAR?=testapp   如果之前VAR没有被定义,则定义并使用testapp;否则使用之前的值

例如:

$vim makfile

APPNAME=link      //定义一个变量并赋值

LIB_SRCS=lingker.c file.c test.c    //库包含哪些C文件,把自己所需要的*.c文件列举在这里

LIB_NAME=linker     //库的名字希望叫什么

LIB_PATH=.libs     //库希望安装到那个路径下去


CFLAGS+=-I${LIB_PATH}   //CFLAGS一般为编译的选项,-I(大写字母i)指定到哪里找头文件

LDFLAGC+=-L{LIB_PATH} -l${LIB-NAME}   //链接选项,-L指定到哪里找这个动态库。-l(小写l)指定哪一个库

上面只是文件的一部分



#第一条目标为总的目标,
#依赖可以是文件(目录)或为其他目标
#动作可以是Linux命令,动作的那一行第一个字符必须是以TAB键
target:   depend1  depend2 depend3 ...
[TAB]  action1  
[TAB ] action2
target1:
[TAB] action1 
[TAB] action2

一个简单的makefile实例:

$rm -rf makefile

$gcc linker.c hello.c test.c    //编译之前建好的*.c文件。

$vim makefile

all:   //目标,可以没有依赖

gcc linker.c hello.c test.c     //动作,注意gcc前面第一个字符不是空格,必须使用TAB键

$make     //以后需要编译相应*.c文件,只需要敲make就可以了,方便,省时。

$vim makefile

APP=link  //编译的时候给它取个名字

all:

gcc linker.c hello.c test.c -o ${APP}

clean:

rm -rf  ${APP}    //删除文件名

$make   //执行总的目标,程序的第一个目标为总的目标(本程序为all)

$make clean   //执行指定clean目标

敲make为执行程序总目标,敲make +加 一个目标名,则执行指定这个目标。

makefile的规则集就是告诉make怎么来编译这个文件的源代码的

一个文件既可以在gcc上编译,也可以在ARM上编译,则可如下定义:

$vim makefile

APP=link  //编译的时候给它取个名字

#GCC=gcc    //注释了,希望在ARM上跑

GCC=arm-linux-gcc

all:

${GCC} linker.c hello.c test.c -o ${APP}

clean:

rm -rf  ${APP}  

$make

$file link   //程序就可以在ARM板上跑了

注意:在makefile中取变量的值时,${}表示确变量的值

makefile在可执行的过程中制作一个静态库;

$vim makefile

APP=link  //编译的时候给它取个名字

GCC=gcc

#GCC=arm-linux-gcc     //注释了,需要在gcc上跑

all:

${GCC} linker.c hello.c test.c -o ${APP}

static_lib;

gcc -c *.c

ar -rcs libzhangsan.a *.o   //做完一个静态库

rm -rf *.o     //希望把所有*.o文件删除

clean:

rm -rf  ${APP}  

$make static_lib

makfeil依赖的实例;

$vin makfile 

APP=link  //编译的时候给它取个名字

#GCC=gcc

GCC=arm-linux-gcc

all: static_lib shared_lib install  //依赖,把制作的动态库放到某个路径下去

${GCC} linker.c hello.c test.c -o ${APP}

static_lib:

gcc -c *.c

ar -rcs lizhangsan.a *.o

rm -rf *.o

shared_lib:

gcc -shared -fPIC -o libzhangsan.so *.c   //制作动态库

install:

mkdir .libs

mv lib*.a lib*.so .libs

clean:

rm -rf  ${APP}  

$make    //先编译static_lib,再编译shared_lib,然后再放到install新建的文件夹.libs下去。

想屏蔽屏幕上无聊的答应信息,可以在相应每行命令之前加上@符。

Makefile的使用:

make  找makefile或Makefile文件执行总的目标
make clean 执行makefile文件中的clean目标
make -C directory 进入到directory文件夹中去执行总的目标
make clean -C direcotry  进入到directory文件夹中去执行clean目标
make -f comm_makefile   通过-f选项指定一个makefile文件
make VAR=value  给Makefile传一个参数VAR,其值为value



Makefile的实例:

$vim makefile

APPNAME=link


LIB_SRCS=linker.c
LIB_NAME=linker
LIB_PATH=.libs


CFLAGS+=-I${LIB_PATH}
LDFLAGS+=-L${LIB_PATH} -l${LIB_NAME}


all: clean static_lib shared_lib install
        gcc ${CFLAGS} main.c -o ${APPNAME}_static ${LDFLAGS} -static
        gcc ${CFLAGS} main.c -o ${APPNAME}_shared ${LDFLAGS} 
        @rm -f *.o


static_lib: linker.c
        gcc -c ${LIB_SRCS}
        ar -rcs lib${LIB_NAME}.a *.o
        rm -f *.o


shared_lib: 
        @gcc -fPIC -shared ${LIB_SRCS}  -o lib${LIB_NAME}.so


clean:
        @rm -f *.o


distclean:
        rm -rf .libs
        rm -rf ${APPNAME}_*


install:
        mkdir -p ${LIB_PATH}
        mv lib${LIB_NAME}.* ${LIB_PATH}
        cp linker.h ${LIB_PATH}

$ ls
linker.c  linker.h  main.c  makefile



$ make
$ make install
$ make clean
$ make distclean


你可能感兴趣的:(Makefile简介及相关用法)