嵌入式Linux学习笔记(3)-Makefile基础

一、简介

        makefile是一种工程管理文件,常被用于C/C++项目的编译管理。它提供了一种灵活且可扩展的方式来管理项目中的源代码和目标文件,并支持自定义编译规则和环境配置。

        说白了 Makefile 就类似于Linux命令行,可以选择性的编译所需文件,在一些大型项目上,如果改动小部分代码,就可以只编译这一部分代码。

二、Makefile格式

        首先得在项目的工作目录下创建一个 Makeflie 的文件,在这个文件中输入规定的语法,表示出依赖关系与编译规则。

Makefile内容通常由以下三部分组成:

<目标名称>:<前置依赖>

\t<需要执行的命令>(\t 是一个制表位

1、编译项目

# 放在第一个的是默认目标
# 目标是编译出main文件 依赖hello.o和main.o文件
# 编译的命令是gcc hello.o main.o -o main
main: hello.o main.o
	gcc hello.o main.o -o main

# gcc -c main.c -o mian.o 可简写 gcc -c main.c
main.o: main.c hello.h
	gcc -c main.c

hello.o: hello.c hello.h
	gcc -c hello.c

# Makefile中存在自动推导,
# 可以只写如下代码,其余可自己推导出来
# main.o: hello.h 
# hello.o: hello.h

2、执行项目

        编译该项目,即执行该Makefile文件,可以在终端输入:

make

        在编译完生成可执行文件后可以直接直接在终端输入如下命令来执行该文件(确保当前工作目录在该项目中):

make ./main    //main为生成的可执行文件名称

        也可以在 Makefile 文件中加入如下代码:

    ./main

3、删除中间文件

clean:
	rm main main.o hello.o

4、优化代码

        定义变量来代替重复部分,要替换重复部分时,在被替换部分加上 $(要替换的部分)

# 定义变量 objects,
# 下面代码的hello.o main.o 就可替换为$(objects)
objects := hello.o main.o

main: $(objects)
	gcc $(objects) -o main

        声明伪目标防止有重复文件名与系统变量名重复;

# 声明伪目标(防止工作目录中存在重名文件)
.PHONY : clean

        加上 - 表示忽略重复执行的错误,比如重复删除文件,第二次删除文件的时候就会报删除的文件不存在的错误,加上 - 就会忽略此错误;

# 忽略错误,即加上-后,重复执行的命令不再报错
clean:
 	-rm main $(objects)

5、书写一般格式

# 宏定义编译器
CC:=gcc

# $@ 相当于目标文件的名称fprintf_test
# $^ 相当于所有依赖文件列表,名称fprintf_test.c
# ./$@ 执行目标文件
# rm./$@ 执行完毕后删除目标文件
fprintf_test:fprintf_test.c
	-$(CC) -o $@ $^
	-./$@
	-rm ./$@

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值