Makefile学习3

小白学习总结的应用实例

首先的我的目录结构是这样的:

                        

相应的makefile 的内容:

all:test

CC=gcc
CFLAGS 	+= -Wall 
CFLAGS 	+= -Werror -g


#CLIBS=-lpthread -lm 

INCLUDES=$(wildcard \
./test1/*.h \
./test2/*.h \
./test3/*.h \
)

SOURCES=$(wildcard \
./*.c \
./test1/*.c \
./test2/*.c \
./test3/*.c \
)


INCLUDES_DIRS=-I./test1 \
-I./test2 \
-I./test3

TARGET=test
OBJECTS=$(patsubst %.c,%.o,$(SOURCES))

$(TARGET):$(OBJECTS)
	$(CC) $(CFLAGS) $^ -o $@ $(CLIBS)
	rm -fr $(OBJECTS)
	
$(OBJECTS):%.o:%.c
	$(CC) -c $(CFLAGS) $< -o $@ $(INCLUDES_DIRS)
clean:
	rm -fr $(TARGET) $(OBJECTS)
.PHONY:clean
  • 关于CFLAGS详解

https://blog.youkuaiyun.com/xinyuan510214/article/details/50457433?depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-1&utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromBaidu-1

  • 关于wildcard用法

 $(wildcard pattern)    # pattern定义了文件名的格式,
                                  # wildcard取出其中存在的文件

https://blog.youkuaiyun.com/liangkaiming/article/details/6267357

  • 关于 -I(大写的 i 值)

include 的意思,-Idir 意指把dir这个目录当作编译器搜寻头文件的目录

 

$(patsubst pattern,replacement,$(var))  # 从列表中取出每一个值
                                                               # 如果符合pattern
                                                               # 则替换为replacement

一篇好的makefile讲解

https://blog.youkuaiyun.com/zhemingbuhao/article/details/88207566

目前都是网络学的知识,在这里做一下记录,自己的成长历程
 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值