Makefile语法

make通过Makefile来组织软件项目的编译

基本语法

Makefile的基本语法如下:

复制代码
目标:依赖项
	编译命令

比如,如下一个示例

复制代码
test: chacha20.cpp test.cpp
	g++ test.cpp chacha20.cpp -o test -lsodium

表示生成目标文件test,依赖项为chacha20.cpp和test.cpp文件,执行命令为

g++ test.cpp chacha20.cpp -o test -lsodium

编译生成test可执行文件

源代码目录包含chacha20.cpp, test.cpp文件和Makefile文件

在目录下执行

$ make

系统会自动执行命令

g++ test.cpp chacha20.cpp -o test -lsodium

生成可执行文件test

变量赋值

可以在Makefile中使用变量,如下

复制代码
CC = g++
SRCS = test.cpp chacha20.cpp
FLAGS = -lsodium
OUTPUT_FILE = test

test: $(SRCS)
	$(CC) $(SRCS) -o $(OUTPUT_FILE) $(FLAGS)

clean:
	rm test

通过变量来指定编译的工具(g++),源代码文件(SRCS),编译选项(FLAGS),输出文件(OUTPUT_FILE)等,然后在执行命令中可以用这些参数来替代相应位置。

增加了clean选项,表示清理编译输出,在这里就是删除生成的test文件,当执行

$ make clean

之后,程序会清除输出文件

相关推荐
hjjdebug9 天前
buildroot 入门介绍
makefile·buildroot
hjjdebug9 天前
buildroot Makefile include *.mk 的玄机.
makefile·buildroot
Zevalin爱灰灰14 天前
makefile从入门到实战 第一章 认识makefile(二)
makefile
Zevalin爱灰灰15 天前
makefile从入门到实战 第一章 认识makefile(一)
linux·makefile
A_humble_scholar15 天前
Linux(三)深入理解 Makefile:自动变量、增量编译原理与文件时间属性
linux·服务器·c++·makefile
sulikey20 天前
个人Linux操作系统学习笔记4 - makefile
linux·makefile·make·构建
Irissgwe1 个月前
二、Linux基础开发工具(2)
linux·makefile·gcc·g++·
量子炒饭大师1 个月前
【Linux系统编程】——【自动化构建-make/Makefile】拒绝手动编译!构建你的赛博代码加工厂,重塑逻辑矩阵效率极限
linux·运维·自动化·makefile·make·自动化构建
yuanyuan2o21 个月前
从最小项目开始的 CMake 教程
c语言·开发语言·arm开发·c++·makefile·make·cmake
李日灐2 个月前
< 6 > Linux 自动化构建工具:makefile 详解 + 进度条实战小项目
linux·运维·服务器·后端·自动化·进度条·makefile