由浅入深C系列七:工欲善其事,必先利其器,从一个makefile模板开始

从一个makefile模板开始

  • 简介
    • makefile结构
    • makefile实例

简介

makefile结构

关于makefile的结构,这个网上介绍的文章很多,就不重复了。需要的读者可以参考网上的文章。这里主要介绍几个重要的内置变量。

$@  表示目标文件
$^  表示所有的依赖文件
$<  表示第一个依赖文件
$?  表示比目标还要新的依赖文件列表

以及几个在makefile里用到的默认规则。

wildcard   
# 扩展通配符 $(wildcard ) 
# 下面的例子中,$(wildcard ./*.cpp)的用法是
# 将所有的匹配.cpp文件列,展开成一个列表返回

patsubst   
# 替换通配符 $(patsubst ,,),将SRC用PATTERN替换成DST
# 下面的脚本例子中$(patsubst %.cpp,%.o,$(SRCS))的用法是
# 取$(SRC)中的内容,将所有的.cpp替换成.o

makefile实例

TARGET是最终编译后生成的发布目录,执行gmake/make都可以。

# myprogram替换成实际的应用名称
TARGET:=./dist/myprogram
build=release
arch=x86_64

CC=g++

CPPFLAGS=-Wall -std=c++11
INCLUDES=-I./\
         -I./include/rapidxml/\
                 -I./include/nsp/

SRCS+=$(wildcard ./*.cpp) $(wildcard ./include/nsp/*.cpp)
OBJS:=$(patsubst %.cpp,%.o,$(SRCS))

LDFLAGS+=-lm -lpthread -ldl -lrt
ifeq ($(build), debug)
        CPPFLAGS+=-g
else
        CPPFLAGS+=-O2
endif

LDFLAGS +=/usr/lib64/libpcap.so \
          ./lib/nshost.so.9.7.8 \
        -Wl,-rpath=/usr/local/lib64/ -L /usr/local/lib64/

$(TARGET): $(OBJS)
        $(CC) $^ -o $@  $(LDFLAGS)

all:
        $(TARGET)

.cpp.o:
        $(CC) -c $< $(CPPFLAGS) $(INCLUDES) -o $@

.PHONY:clean all install

clean:
        $(RM) $(OBJS) $(TARGET)

你可能感兴趣的:(Unix/Linux,C/C++,c语言,开发语言,Makefile)