Linux工程管理器——Makefile

 

makefile 文件  ===>  创建文件名为makefile 或者 Makefile的文件(无后缀)

 

1、makefile的规则


    书写规则:
    目标文件:依赖文件
    (一个tab键) 命令

    命令前面的tab键不能用空格代替
    目标文件    最终要生生成的文件
    依赖文件    为了生成目标文件需要的文件
    命令    通过依赖文件生成目标文件的方法

运行:执行 make 命令,执行命令的时候可以加 “-n”,代表不真正执行命令,只是预览要执行的命令

    伪目标的写法:
    目标:(空的)
        命令
    伪目标不会生成目标文件,执行 :make 名字 执行相应命令
    常用:
    clean    清除相关文件
    all/ALL    最终要生成的目标,不要写命令
    clean的命令前可以加‘-’,目的:当删除某些文件失败的时候,可以让命令继续执行下去

    
    执行规则:
    1、如果目标文件的时间早于依赖文件,则重新生成目标文件
    2、如果依赖文件不存在,则会去找相应的规则生成依赖文件
    
    2、函数
       makefile中变量不需要类型,例如:src=abc
       取变量的值用 $(变量)  ===>   $(src)    ===>   abc
    wildcard    $(wildcard   *.c)    匹配当前目录下所有.c 文件
    patsubst    $(patsubst %.c,  %.o , $(src))    
    src = $(wildcard   *.c)                        ==> src =  main.c  add.c  mul.c  sub.c
    obj= $(patsubst %.c,  %.o , $(src))    ==> obj =  main.o  add.o  mul.o  sub.o 
    
    3、自动变量
    $(@)    代表规则中的目标文件
    $(^)    代表规则中的所有依赖文件
    $(<)    代表规则中的第一个依赖文件
    
    模式匹配:
        %.o:%.c

    注意:
    伪目标最好写在.PHONY后面声明一下,否则如果当前文件夹下存在和伪目标相同的文件,则伪目标将失效
 

makefile文件模板:

src = $(wildcard *.c)        
obj = $(patsubst %.c, %.o, $(src))  

target=a.out    //可执行文件名
all:$(target)

$(target):$(obj)
	gcc $(^) -o $(@)   

%.o:%.c
	gcc -c $(^) -o $(@)  
	
.PHONY:clean all
clean:
	-rm -rf $(target) $(obj)

	
	
	

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值