码迷,mamicode.com
首页 > 系统相关 > 详细

Linux中makefile项目管理

时间:2019-05-14 12:57:52      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:sub   变量   原则   alt   obj   匹配   文件的时间   自动   目标   

一、整体大纲

技术图片

二、makefile的编写

一个规则   两个函数  三个变量

1. 一个规则

    三要素: 目标, 依赖, 命令
    目标:依赖
    命令
    1) 第一条规则是用来生成终极目标的规则
            a. 如果规则中的依赖不存在, 向下寻找其他的规则,
            b. 更新机制: 比较的是目标文件和依赖文件的时间       

2. 两个函数

    1) 查找指定目录下, 指定类型的文件
           src=$(wildcard ~/aa/*.c)
    2)匹配替换函数
            obj=$(patsubst %.c, %.o, $(src))

3. 三个自动变量

        1)$<: 规则中的第一个依赖
        2) $^: 规则中的所有依赖
        3)$@: 规则中的目标

        只能在规则中的命令中使用

4. 模式规则
        %.o:%.c
            gcc -c $< -o $@

技术图片

子目标和终极目标的关系:
更新目标的原则:

 技术图片

技术图片

三、makefile中变量的使用

       makefile编写示例:

 技术图片

app:main.o sub.o mul.o
  gcc main.o sub.o mul.o -o app
  gcc $^ -o $@
        
%.o:%.c 
  gcc -c $< -o $@

      makefile中的自动变量:

  • $<: 规则中的第一个依赖
  • $@: 规则中的目标
  • $^: 规则中的所有依赖

      只能在规则的命令中使用

Linux中makefile项目管理

标签:sub   变量   原则   alt   obj   匹配   文件的时间   自动   目标   

原文地址:https://www.cnblogs.com/xuejiale/p/10788404.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!