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

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

相关推荐
阿昭L1 天前
Windows通用的C/C++工程CMakeLists
c语言·c++·windows·makefile·cmake
数字IC那些事儿4 天前
CMakeLists.txt 语法解释
makefile·system c
一只自律的鸡2 个月前
【MakeFile】基础培训2
makefile
tod1132 个月前
Makefile进阶(上)
linux·运维·服务器·windows·makefile·进程
一个平凡而乐于分享的小比特2 个月前
Makefile 源码编译系统详解
linux·makefile
一个平凡而乐于分享的小比特3 个月前
Autoconf:Linux自动生成Makefile的详解
makefile·cmake·autoconf
一个平凡而乐于分享的小比特3 个月前
Linux内核构建三剑客:Kconfig、.config与Makefile关系详解
linux·makefile·kconfig·.config
ベadvance courageouslyミ3 个月前
项目一(线程邮箱)
c语言·线程·makefile·进程间通信·线程邮箱
熊猫钓鱼>_>3 个月前
Makefile应用场景实践日志:构建高效C/C++项目工作流
c语言·c++·bug·mfc·makefile·编译·kmp