makefile语法

 makefile主要由规则,变量,条件执行,文本,文本名处理函数,文件包含,注释组成。    

     先来看一段makefile程序

  ifeq($(DEBUG),"true")#条件执行

         CC=gcc -g#CC是变量,通过$(DEBUG)符号来引用变量,gcc -g就是生成debug文件

else

         CC=gcc

endif

all:hello

 hello:lcd.o,player.o

         $(CC)  -o hello lcd.o player.o#这些都是规则,规则是makefile的基本单元。

player.o:player.c

       $(CC) -o player.o -c player.c

lcd.o:lcd.c
$(CC) -o lcd.o -c lcd.c

clean:
rm lcd.o hello player.o

makefile的主要内容;

•规则
     •构成Makefile的基本单元、构成依赖关系的核心部件
    •其它内容可以看作为规则服务
    语法是
           生成文件:依赖文件
                   命令
•变量
     •类似于C语言中的宏,引用:$(VAR)、${VAR}
    •可以让Makefile更加灵活
•条件执行
   •根据某一变量的值来控制make执行或者忽略Makefile的某一部分
•函数
   •文本处理函数:字符串替换、查找、过滤、排序、统计等
   •文件名处理函数:取目录/文件名、前后缀、加前缀/后缀、单词连接等函数
   •其它常用函数:if函数、shell函数、foreach函数
•文件包含
    •类似于C语言的#include,使用include命令
•注释
    •使用#开头,表示注释

makefile最终要生成关系依赖树

上面程序要生成的依赖树是


编译程序时关系依赖树加入到内存中。每次当文件更新或者删除增加文件,依赖树改变,那么需要重新编译

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值