2019-04-02 嵌入式linux学习01

Makefile 的引入及规则

gcc -o file file.c 预处理-编译-汇编-链接 file.i -> file.s -> file.o -> file 缺点是对所有的文件再处理一次,在文件非常多时耗时非常长。应该分别编译,最后链接。


gcc -c -o a.o a.c

gcc -c -o b.o b.c

gcc -o test a.o b.o

如何判断哪些文件被修改了?通过比较a.c(b.c,a.o b.o)与a.o(b.o,test)的文件最后修改时间。

Makefile基本的语法规则

目标文件:依赖文件1 依赖文件2 ....

[TAB]——命令

当依赖比目标新,执行命令


test:a.o b.o

    gcc -o test a.o b.o

a.o:a.c

    gcc -c -o a.o a.c

b.o:b.c

    gcc -c -o b.o b.c

a.通配符:%.o b.假想目标:.PHONY c.即时变量、延时变量,export

a.通配符的用法举例


test:a.o b.o

    gcc -o test a.o b.o

%.o:%.c

    gcc -c -o $@ $<


test:a.o b.o c.c

    gcc -o test $^

%.o:%.c

    gcc -c -o $@ $<

$@ 表示目标

$< 表示第一个依赖文件

$^ 表示所有的依赖文件

b.假想目标


test:a.o b.o c.c

    gcc -o test $^

%.o:%.c

    gcc -c -o $@ $<

clean:

    rm *.o test

.PHONY:clean/*假想目标*/

make [目标名] 若无目标,执行第一个

c.即时变量,延时变量

简单变量(即时变量):A := xxx #A的值即可确定 B = xxx #B的值使用到时才确定


A := abc

B = 123

all:

    @echo $(A)

    @echo $(B)


:= #即时变量

= #延时变量

?= #延时变量,如果是第一次定义才有效,如果在前面该变量已定义则忽略这句

+= #附加,它是即时变量还是延时变量取决于前面的定义


Makefile函数

a. $(foreach var,list,text)

b. $(filter pattern...,text) 在text中取出符合pattern格式的值

$(filter-out pattern...,text) 在text中取出不符合pattern格式的值

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

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

Linux Makefile 生成 *.d 依赖文件及 gcc -M -MF -MP 等相关选项说明 - Jerry - CSDN博客

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 来自陈浩的一片老文,但绝对营养。 示例工程:3 个头文件*.h,和 8 个 C 文件*.c。 初 编译过程,源文件...
    周筱鲁阅读 10,157评论 0 17
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 10,007评论 0 5
  • 1.Makefile规范 target 这 一 个 或 多 个 的 目 标 文 件 依 赖 于prerequisi...
    G风阅读 6,049评论 0 3
  • makefile关系到整个工程的编译规则,一个工程中的源文件不计其数,按其类型、功能、模块分别放在若干的目录当中,...
    Joe_HUST阅读 5,887评论 0 3
  • Lua 5.1 参考手册 by Roberto Ierusalimschy, Luiz Henrique de F...
    苏黎九歌阅读 14,755评论 0 38

友情链接更多精彩内容