首页 > 系统相关 >嵌入式Linux—浅析Makefile

嵌入式Linux—浅析Makefile

时间:2023-02-12 18:44:06浏览次数:48  
标签:文件 变量 make Makefile clean Linux test 执行 浅析

Makefile文档

组织管理程序

不使用Makefile的缺点

-o test a.c b.c

执行过程:

a.c文件通过预处理、编译、汇编得到a.o文件

b.c文件通过预处理、编译、汇编得到b.o文件

a.o文件与b.o文件通过链接,得到test可执行文件

这种方式的缺点:如果仅仅对a.c文件内容进行修改,执行命令后,b.c文件也会重新编译、链接,效率降低。

Makefile的规则

makefie最基本的语法是规则,规则:

目标 : 依赖1 依赖2 ...
[TAB]命令

当“依赖”比“目标”新,执行它们下面的命令。我们要把上面三个命令写成makefile规则,如下:

test :a.o b.o  //test是目标,它依赖于a.o b.o文件,一旦a.o或者b.o比test新,就执行下面的命令,重新生成test可执行程序。
	gcc -o test a.o b.o
a.o : a.c  //a.o依赖于a.c,当a.c更加新的话,执行下面的命令来生成a.o
	gcc -c -o a.o a.c
b.o : b.c  //b.o依赖于b.c,当b.c更加新的话,执行下面的命令,来生成b.o
	gcc -c -o b.o b.c
通配符

假如一个目标文件所依赖的依赖文件很多,那样岂不是我们要写很多规则,这显然是不合乎常理的.我们可以使用通配符,来解决这些问题。

对上节程序进行修改代码如下:

test: a.o b.o 
	gcc -o test $^
	
%.o : %.c
	gcc -c -o $@ $<

%.o:表示所用的.o文件

%.c:表示所有的.c文件

$@:表示目标

$<:表示第1个依赖文件

$^:表示所有依赖文件

假想目标:.PHONY

我们想清除文件,我们在Makefile的结尾添加如下代码就可以了:

clean:
	rm *.o test

*1)执行 make :生成第一个可执行文件。
*2)执行 make clean : 清除所有文件,即执行: rm *.o test。

如果:该目录下面有名为clean文件怎么办呢?

我们在该目录下创建一个名为 “clean” 的文件,然后重新执行:make然后make
clean,结果(会有下面的提示:):

make: \`clean' is up to date.

它根本没有执行我们的删除操作,这是为什么呢?

我们之前说,一个规则能过执行的条件:

*1)目标文件不存在
*2)依赖文件比目标新

解决办法:我们需要把目标定义为假象目标,用关键字PHONY

.PHONY: clean //把clean定义为假象目标。他就不会判断名为“clean”的文件是否存在,

然后在Makfile结尾添加.PHONY: clean语句,重新执行:make clean,就会执行删除操作。

变量

在makefile中有两种变量:

1), 简单变量(即使变量):

A := xxx # A的值即刻确定,在定义时即确定

2)延时变量

B = xxx # B的值使用到时才确定

:= # 即时变量
= # 延时变量
?= # 延时变量, 如果是第1次定义才起效, 如果在前面该变量已定义则忽略这句
+= # 附加, 它是即时变量还是延时变量取决于前面的定义
?= # 如果这个变量在前面已经被定义了,这句话就会不会起效果,

实例:

A := $(C)
B = $(C)
C = abc

D = hello
D ?= world

all:
	@echo A = $(A)  # $(变量名)表示变量值
	@echo B = $(B)
	@echo D = $(D)

C += 123

执行:

make

结果:

A =
B = abc 123
D = hello

标签:文件,变量,make,Makefile,clean,Linux,test,执行,浅析
From: https://www.cnblogs.com/Tayoou/p/17114424.html

相关文章

  • 嵌入式Linux—Framebuffer应用编程
    Framebuffer应用编程Frame的意思是帧,buffer的意思是缓冲区。Framebuffer就是一块内存(硬件设备),里面保存着一帧图像。ioctl()函数解析ioctl()函数非常强大。不同的驱......
  • linux驱动架构
    linux驱动演化过程:从04年到现在,linux驱动进行了两次大的演变,从基于linux-v2.4的原始架构---到基于linux-v2.6的平台总线---再到现在的基于linux-v3.x的设备树。这个演变过......
  • Linux基础命令-history历史记录
    前言    在工作中,经常会需要多次重复某一个命令,或者需要查看之前执行过什么命令,那么都少不了history这个命令,下面一起来看看吧。一、history命令介绍    hi......
  • Linux基础命令-date设置时间
    前言    服务器上的时间往往要用到这个命令,而date命令能修改的不仅仅是时间,还可以修改时区,同步大厂的时间等。一、date命令的介绍    date命令来自于英文单......
  • Linux文件管理命令(4)-cat查看文件内容
     前言    cat主要是用来查看文件内容的,一般也搭配管道符一起来使用,比如有时候要计算文件有多少行或者要截取里面的内容,都还是很实用的。一、cat命令介绍   ......
  • Linux文件管理命令-head显示文件开头的内容
    前言    head命令在日常比较常用的一个命令,如果只想查看文件的前几行内容,就可以用这个命令,还可以自定义选择要查看多少行,一起来看看这个命令的使用吧。一、head命令......
  • linux系统编程
    linux应用编程也叫linux系统编程,应用程序可以通过系统调用直接调用内核或者通过标准库来调用内核,前者在arm系统中通过软中断来实现。linux系统编程的内容如下:一、文件IO......
  • [转]linux查询公网ip(即提供返回公网ip的网站API)
    原文地址:linux下使用命令行获取公网ip地址-简书(jianshu.com)有时候需要获得本机的公网IP地址,如果在Linux下只能通过命令行获取公网ip地址的话,可以参考本文收集的几......
  • linux环境千万数据导入mysql遭遇问题
    看黑马mysql视频有数据是一千万条数据,分批使用loadfile方式导入数据库表的时候出现了导入失败问题表结构CREATETABLE`tb_sku`(`id`int(11)NOTNULLAUTO_INC......
  • Linux学习-day9
    第六章存储结构与管理硬盘6.1一切从“/”开始Linux系统中一切都是文件​Linux系统中的一切文件都是从“根”目录(/)开始的,并按照文件系统层次标准(FHS)采用倒树状结构来存放......