玩转Makefile | 企业项目Makefile实例

原创 2018年04月16日 20:30:43
1. 前言
本教程展示了一个比较完整的企业项目级别的Makefile文件,包括了:版本号、动态库、宏定义等内容。

2. 程序展示
本例程的程序目录结构在企业项目中经常见到,即:所有.c文件全部放在一个src目录中,所有.h文件放一个.h目录中,生成的目标独立放在一个output目录中(动态生成)。

      源代码可以从这里获取。

目录结构如下:
源程序为:
//fun1.h
void fun1();


//fun1.c
void fun1()
{
	printf("this is fun1\n");
}


//fun2.h
void fun2();


//fun2.c
void fun2()
{
	printf("this is fun2\n");
}


//dylib.h
void dynamic_lib_call();


//main.c
int main()
{
	printf("hello world\n");
	fun1();
	fun2();

#ifdef _MACRO
	printf("macro test\n");
#endif
	dynamic_lib_call();
}
Makefile文件为:
VERSION = 1.0.0		#程序版本号

SOURCE = $(wildcard ./src/*.c)	#获取所有的.c文件
OBJ = $(patsubst %.c, %.o, $(SOURCE))	#将.c文件转为.o文件
INCLUDES = -I./h	#头文件路径

LIBS = -ldylib		#库文件名字
LIB_PATH = -L./lib	#库文件地址

DEBUG = -D_MACRO	#宏定义
CFLAGS = -Wall -c	#编译标志位

TARGET = app
CC = gcc

$(TARGET): $(OBJ)	
	@mkdir -p output/	#创建一个目录,用于存放已编译的目标
	$(CC) $(OBJ) $(LIB_PATH) $(LIBS) -o output/$(TARGET).$(VERSION)

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

.PHONY: clean
clean:
	rm -rf $(OBJ) output/ 
库文件说明:
库文件名称为libdylib.so,里面只有一个函数:dynamic_lib_call(),它就输出一句话:this is a function in dynamic library。

3. Makefile所包含内容
3.1 程序版本
软件开发过程中,会产生多个版本程序,通常会在程序末尾加上版本号后缀。
VERSION = 1.0.0	#定义
$(CC) $(OBJ) $(LIB_PATH) $(LIBS) -o output/$(TARGET).$(VERSION)	#使用
3.2 头文件
由于.c文件与.h文件分开在不同目录下,所以应指定头文件路径。
INCLUDES = -I./h 
3.3 宏定义
在代码调试的过程中,我们通常会加个宏定义来控制此段代码是否被编译,比如:
#ifdef _MACRO
    printf("macro test\n");
#endif
具体的宏我们可不定义在代码里,可在Makefile里指定,比如:
DEBUG = -D_MACRO 	#定义
$(CC) $(INCLUDES) $(DEBUG) $(CFLAGS) $< -o $@	#使用
3.4 编译选项
当编译选项较多时,我们通常会把它单独拿出来,比如:
CFLAGS = -Wall -c		#定义
$(CC) $(INCLUDES) $(DEBUG) $(CFLAGS) $< -o $@	#使用
3.5 库
代码里如果要使用到库,我们可以将库名字和路径分别拿出来,比如:
LIBS = -ldylib          #库文件名字
LIB_PATH = -L./lib      #库文件地址
$(CC) $(OBJ) $(LIB_PATH) $(LIBS) -o output/$(TARGET).$(VERSION)	#使用
3.6 output目录
如果不想把生成的程序与源文件混在一起,可将生成的程序单独放在一个output目录,比如:
$(TARGET): $(OBJ)
        @mkdir -p output/       #创建一个目录,用于存放已编译的目标
        $(CC) $(OBJ) $(LIB_PATH) $(LIBS) -o output/$(TARGET).$(VERSION)
4. 编译执行结果

5. 作者介绍
本人是一名Linux应用开发工程师,目前供职于一家世界500强公司,主要负责车联网产品的研发。喜交天下好友,欢迎添加本人微信一起学习、交流!





版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/yychuyu/article/details/79965573

一个很好的makefile例子(经典)

转自http://www.cnblogs.com/sld666666/archive/2010/04/08/1707789.html 相信在unix下编程的没有不知道makefile...
  • dongdong0071
  • dongdong0071
  • 2016-07-26 23:09:04
  • 6984

makefile的编写实例(windows vs2010)

######################### Read Me ######################### # 任何版本的vs都是支持makefile编译的 # ...
  • fwqcuc
  • fwqcuc
  • 2010-12-17 13:38:00
  • 7048

Makefile详解和实例

Makefile隐含规则使用的变量 在隐含规则中的命令中,基本上都是使用了一些预先设置的变量。你可以在你的makefile中改变这些变量的值,或是在make的命令行中传入这些值,或是在你的环境变量中...
  • earbao
  • earbao
  • 2013-12-25 10:20:07
  • 1904

Makefile 编写实例

近几天因工作需要编写Makefile,于是在网上搜索相关资料学写Makefile 时间比较仓促 但总还算达到了软件代码自动化编译的目的,参考主要资料来源于网上一位大神《跟我学写Makefile》博客,...
  • suanfayanxueruizhuce
  • suanfayanxueruizhuce
  • 2016-06-12 20:35:08
  • 601

从简单实例开始,学会写Makefile(一)

作为一个刚刚从大学囚笼里走出的新人,进公司不久就遇到了一个不大不小的门槛——看不懂Makefile!虽然还不至于影响到项目进度,从别的地方拷贝一份过来稍加修改就可以用了,但是,对于咱们“程序猿”来说这...
  • wcl199274
  • wcl199274
  • 2014-09-08 22:42:42
  • 1538

Makefile 的编写过程(实践)

本读不讲理论,只讲实践。 适用对象,有GCC基础,对GCC编译有了解的人群。   1、先了解程序从无到有的过程,即编译到执行。 (图片的引用来自互联网) 下面用实例来演示整个过程。 以...
  • fengsh998
  • fengsh998
  • 2012-11-10 22:26:36
  • 3549

makefile实例

  • 2012年08月19日 12:51
  • 283B
  • 下载

makefile深度学习(一个工程实例来学习 Makefile)

转自 http://www.cnblogs.com/OpenShiFt/p/4313351.html?utm_source=tuicool&utm_medium=referral Makefil...
  • u014805066
  • u014805066
  • 2017-03-20 14:50:10
  • 336

编写Makefile

 本博客(http://blog.csdn.net/livelylittlefish)贴出作者(三二一、小鱼)相关研究、学习内容所做的笔记,欢迎广大朋友指正! 编写Makefile  1. 一个例子 ...
  • livelylittlefish
  • livelylittlefish
  • 2009-01-28 23:07:00
  • 25212

一个最简单的Makefile例子

原文地址:http://hi.baidu.com/hellosim/blog/item/42e78341b40c3e8db2b7dce3.html 转载请注明出处 1.hello.c #in...
  • u013713010
  • u013713010
  • 2015-05-25 10:10:43
  • 4026
收藏助手
不良信息举报
您举报文章:玩转Makefile | 企业项目Makefile实例
举报原因:
原因补充:

(最多只允许输入30个字)