常用Makefile模板

转:http://blog.csdn.net/yusiguyuan/article/details/23877935

在linux下面,我们不得不自己写makefile,makefile的确博大精深,但是实际上对于日常的使用来说,无非就是
1:编译可执行程序。2:编译lib库 3:编译so库
本博针对上面三种目的各自写出了makefile模版,希望对大家有所帮助。
一.编译可执行程序
当前目录下制定文件编译成可执行文件(连接外部库的话只需要更改INC和LIB即可)

CXX = g++
TARGET = bitmaploctest
C_FLAGS += -g -Wall
LIB_FLAGS = -pthread
all: $(TARGET)
bitmaploctest: bitmaploctest.o bitmaploc.o file_lock.o
$(CXX) -o $@ $^ $(LIB_FLAGS) $(LIB) $(C_FLAGS)
.cpp.o:
$(CXX) -c -o $*.o $(INC) $(C_FLAGS) $*.cpp
.cc.o:
$(CXX) -c -o $*.o $(INC) $(C_FLAGS) $*.cc
clean:
-rm -f *.o $(TARGET)

二.编译成lib库
当前目录下指定文件编译成lib库(一般lib库在编译的时候不会将使用的外部库编译进来,而是等编译成可执行程序时或者.so时)

INC_DIR= ./
SRC_DIR= ./
OBJ_DIR= ./
LIB_DIR= ./
H_DIR= ./
OBJ_EXT= .o
CXXSRC_EXT= .cpp
CSRC_EXT= .c
LIB_EXT= .a
H_EXT= .h
OBJECTS = $(OBJ_DIR)bitmaploc$(OBJ_EXT) \
$(OBJ_DIR)file_lock$(OBJ_EXT)
LIB_TARGET = $(LIB_DIR)libbitmaploc$(LIB_EXT)
$(OBJ_DIR)%$(OBJ_EXT): $(SRC_DIR)%$(CXXSRC_EXT)
@echo
@echo “Compiling $< ==> $@…”
$(CXX) $(INC) $(C_FLAGS) -c $< -o $@
$(OBJ_DIR)%$(OBJ_EXT): $(SRC_DIR)%$(CSRC_EXT)
@echo
@echo “Compiling $< ==> $@…”
$(CC) -I./ $(INC) $(C_FLAGS) -c $< -o $@
all:$(LIB_TARGET)
$(LIB_TARGET): $(OBJECTS)
all: $(OBJECTS)
@echo
$(AR) rc $(LIB_TARGET) $(OBJECTS)
@echo “ok”
clean:
rm -f $(LIB_TARGET) $(OBJECTS)

三.编译成so库
当前目录下指定文件编译成so库(必须将所有引用的外部库都编译进来)

CC = gcc
CXX = g++
CFLAGS = -Wall -pipe -DDEBUG -D_NEW_LIC -g -D_GNU_SOURCE -shared -D_REENTRANT
LIB = -lconfig -ldl -lrt -L../../lib -lttc -g
INCLUDE = -I../spp_inc
OO = service.o tinystr.o tinyxml.o tinyxmlerror.o tinyxmlparser.o uin_conf.o stat.o
TARGETS = ../../lib/libRanch.so
all: $(TARGETS)
stat:tool_stat.cpp
$(CXX) $(INCLUDE) tool_stat.cpp -o tool_stat stat.o tinystr.o tinyxml.o tinyxmlerror.o tinyxmlparser.o -g
cp tool_stat ../../bin
$(TARGETS): $(OO)
$(CXX) $(CFLAGS) $(INCLUDE) $(OO) -o $@ $(LIBDIR) $(LIB)
.c.o:
$(CC) $(CFLAGS) -c $(INCLUDE) $<
echo $@
.cpp.o:
$(CXX) $(CFLAGS) -c $(INCLUDE) $<
echo $@
%:%.c
$(CC) $(CFLAGS) -o $@ $< $(OO) $(LDFLAGS)
echo $@
clean:
rm -f *.o
rm -f $(TARGETS)
rm -f tool_stat

OK,我常用的makefile也就这三种格式,希望对大家有用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
模块化makefile模板是一种将大型软件项目的编译过程分解为多个模块,并通过makefile来管理的方法。它的目的是提高项目的可维护性、可扩展性和可重用性。 首先,模块化makefile模板将整个项目分解为多个模块,每个模块都有自己的源代码文件和依赖关系。这些模块可以是不同的功能模块、库模块或者测试模块。通过将项目划分为模块,使得每个模块都可以独立编译和测试,方便单独管理和开发。 其次,模块化makefile模板定义了每个模块的编译规则和依赖关系。每个模块都有一个对应的makefile文件,其中包含了该模块的编译过程、编译选项、依赖关系和目标文件等信息。通过这些makefile文件,可以根据不同的模块进行编译和链接,极大地提高了编译效率。 此外,模块化makefile模板还提供了一些常用的规则和变量,用于管理整个项目的编译过程。例如,可以定义一个通用的编译规则和链接规则,用于编译和链接所有的模块。还可以定义一些变量,用于指定编译选项、目标文件名和库文件名等。通过统一的规则和变量,可以减少重复的代码和配置,提高了项目的可维护性和可重用性。 综上所述,模块化makefile模板是一种有助于管理大型软件项目的编译过程的方法。通过将项目划分为多个模块,并定义相应的规则和变量,可以提高项目的可维护性、可扩展性和可重用性,并提高编译效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值