cmakelinux模板多⽬录_多个⽂件⽬录下Makefile的写法
1、前⾔
2、简单测试
测试程序在同⼀个⽂件中,共有func.h、func.c、main.c三个⽂件,Makefile写法如下所⽰:
1 CC = gcc
2 CFLAGS = -g -Wall
3
4 main:main.o func.o
5 $(CC) main.o func.o -o mainmakefile phony
6 main.o:main.c
7 $(CC) $(CFLAGS) -c main.c -o main.o
8 func.o:func.c
9 $(CC) $(CFLAGS) -c func.c -o func.o
10 clean:
11 rm -rf *.o
执⾏过程如下图所⽰:
3、通⽤模板
实际当中程序⽂件⽐较⼤,这时候对⽂件进⾏分类,分为头⽂件、源⽂件、⽬标⽂件、可执⾏⽂件。也就是说通常将⽂件按照⽂件类型放在不同的⽬录当中,这个时候的Makefile需要统⼀管理这些⽂件,将⽣产的⽬标⽂件放在⽬标⽬录下,可执⾏⽂件放到可执⾏⽬录下。测试程序如下图所⽰:
完整的Makefile如下所⽰:
1 DIR_INC = ./include
2 DIR_SRC = ./src
3 DIR_OBJ = ./obj
4 DIR_BIN = ./bin
5
6 SRC = $(wildcard ${DIR_SRC}/*.c)
7 OBJ = $(patsubst %.c,${DIR_OBJ}/%.o,$(notdir ${SRC}))
8
9 TARGET = main
10
11 BIN_TARGET = ${DIR_BIN}/${TARGET}
12
13 CC = gcc
14 CFLAGS = -g -Wall -I${DIR_INC}
15
16 ${BIN_TARGET}:${OBJ}
17 $(CC) $(OBJ) -o $@
18
19 ${DIR_OBJ}/%.o:${DIR_SRC}/%.c
20 $(CC) $(CFLAGS) -c $< -o $@
21 .PHONY:clean
22 clean:
23 find ${DIR_OBJ} -name *.o -exec rm -rf {}
解释如下:
(1)Makefile中的 符号 $@, $^, $< 的意思:
$@  表⽰⽬标⽂件
$^  表⽰所有的依赖⽂件
$
$?  表⽰⽐⽬标还要新的依赖⽂件列表
(2)wildcard、notdir、patsubst的意思:
wildcard : 扩展通配符
notdir : 去除路径
patsubst :替换通配符
例如下图例⼦所⽰:
输出结果如下所⽰:
SRC = $(wildcard *.c)
等于指定编译当前⽬录下所有.c⽂件,如果还有⼦⽬录,⽐如⼦⽬录为inc,则再增加⼀个wildcard函数,象这样:
SRC = $(wildcard *.c) $(wildcard inc/*.c)
(3)gcc -I -L -l的区别:
gcc -o hello hello.c -I /home/hello/include -L /home/hello/lib -lworld
上⾯这句表⽰在编译hello.c时-I /home/hello/include表⽰将/home/hello/include⽬录作为第⼀个寻头⽂件的⽬录,寻的顺序是:/home/hello/include-->/usr/include-->/usr/local/include
-L /home/hello/lib表⽰将/home/hello/lib⽬录作为第⼀个寻库⽂件的⽬录,
寻的顺序是:/home/hello/lib-->/lib-->/usr/lib-->/usr/local/lib
-lworld表⽰在上⾯的lib的路径中寻libworld.so动态库⽂件(如果gcc编译选项中加⼊了“-static”表⽰寻libworld.a静态库⽂件)参考:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。