Makefile基础学习

什么是Makefile

为了实现对多个项目文件的编译,我们将编译和处理规则放入到Makefile文件中。通过Makefile工具解析Makefile中的文件来指导整个工程项目的编译过程。
请添加图片描述

Makefile文件的基本规则

请添加图片描述
以t40_sdk_sample中的makefile为例:

sample-Encoder-video: $(SDK_LIB_DIR)/libimp.a $(SDK_LIB_DIR)/libalog.a sample-common.o sample-Encoder-video.o
	$(CPLUSPLUS) $(LDFLAG) -o $@ $^ $(LIBS) -lpthread -lm -lrt
	$(STRIP) $@

​ sample-Encoder-video是所要生成的目标,目标的右边是生成目标所需要的依赖文件,包括静态库和编译文件等;接着下面table键之后是生成目标的执行命令,将库文件和依赖文件链接生成最终的目标可执行文件。

变量的使用

变量赋值
条件赋值: ?=
CROSS_COMPILE ?= mips-linux-gnu-

​ 即如果变量没有被定义过,那么变量的值就是右侧的值,如果变量先前被定义过,则赋值语句不发挥作用

追加赋值: +=
CFLAGS += -muclibc

​ 即在后面追加值

延迟展开赋值: =
x = $(y)
y = hello

​ 不同于我们写代码时的顺序声明,Makefile中等号右侧的变量可以定义在文件中的任意一处

直接展开赋值: :=
x := hello
y := $(x) world

​ 符合顺序声明变量,只能使用前面定义好的变量

​ 如果如下面这种写法,则就有问题,这时x的值就不是hello world,而是world。

x := $(y) world
y := hello
常用的默认自动化变量

​ $^ :表示所有的依赖文件

​ $@:表示生成的目标文件

​ $< :表示第一个依赖文件

%.o:%.c sample-common.h
	$(CC) -c $(CFLAGS) $< -o $@  

包含头文件路径

CFLAGS = $(INCLUDES) -O2 -Wall -march=mips32r2    //-march=mips32r2  编译器针对mips32r2架构优化
INCLUDES = -I$(SDK_INC_DIR)                   
Makefike 打印调试方法

任意位置打印–可选择info warning error

$(info "xxx") 
$(warning "xxx") 
$(error "xxx") 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值