您的位置:首页 > 其它

一点一点学写Makefile-1

2016-06-01 13:53 274 查看
相信很多Linux开发者 都得自己来写Makefile,刚开始学习学写这个的时候都会碰到很多困难,我之前没有自己独立完成过Makefile,都是在公司已有的模板上添加。现在突然有一个很大的想法就是从零开始写Makefile,这个博客就是我的学习笔记。
开始准备我写的代码,总共七个文件,内容都很简单,工程的下载地址是:               下载地址
代码如下:
//add.h

#ifndef ADD_H
#define ADD_H

int add(int a, int b);

#endif // ADD_H

//add.cpp
#include "add.h"

int add(int a, int b)
{
    return a + b;
}

//mul.h
#ifndef MUL_A
#define MUL_A

int mul(int a, int b);

#endif // MUL_A

//mul.cpp
#include "mul.h"

int mul(int a, int b)
{
    return a * b;
}

//sub.h
#ifndef SUB_H
#define SUB_H

int sub(int a, int b);

#endif // SUB_H

//sub.cpp
#include "sub.h"

int sub(int a, int b)
{
return a - b;
}
接下来就是最重要的Makefile文件了
//Makefile
//make.force

CROSS =
CC = $(CROSS)gcc
CXX = $(CROSS)g++
DEBUG = -g -O2
CFLAGS = $(DEBUG) -Wall -c
RM = rm -rf

SRCS = add.cpp sub.cpp mul.cpp main.cpp
OBJS = $(patsubst %.cpp, %.o, $(SRCS))

VERSION = 1.0.0.0
TARGET = test.$(VERSION)

$(TARGET) : $(OBJS)
$(CXX) $^ -o $@

$(OBJS):%.o : %.cpp
$(CXX) $(CFLAGS) $< -o $@

clean:
$(RM) $(TARGET) *.o
好了,这就是我的工程里面所有的代码和文件,这里面有Makefile文件和make.force两个文件,这两个文件的内容完全相同。在执行make命令的时候,系统会自动找到makefile或Makefile文件(注:尽可能使用Makefile名称,因为linux开发项目中,所有的文件名字都是小写,因此为了区分出make文件,将M大写),除此之外也可以手动指定make文件,使用"make -f make.force"来指定将make.force文件作为执行make命令的文件,清理内容是("make clean -f make.force")。
下来,开始一句一句的讲解Makefile文件的命令:
CROSS = //在开发时候,有时候会有嵌入式的选项
CC = $(CROSS)gcc
CXX = $(CROSS)g++
DEBUG = -g -O2 //这里一般设置为空,在编译时候手动指定,例如:make DEBUG="-g -O2"
CFLAGS = $(DEBUG) -Wall -c
RM = rm -rf

SRCS = add.cpp sub.cpp mul.cpp main.cpp //最笨的方法,将所有的.cpp文件添加到SRCS中
OBJS = $(patsubst %.cpp, %.o, $(SRCS)) //通过*.cpp文件获得同名的*.o文件

VERSION = 1.0.0.0 //版本信息
TARGET = test.$(VERSION) //组装文件名和版本信息

$(TARGET) : $(OBJS) //连接
$(CXX) $^ -o $@

$(OBJS):%.o : %.cpp //生成*.o文件
$(CXX) $(CFLAGS) $< -o $@

clean:
$(RM) $(TARGET) *.o
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  makefile