Makefile常用写法

Posted 一只特立独行的猫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Makefile常用写法相关的知识,希望对你有一定的参考价值。

这里写目录标题


Makefile是linux的一种编译脚本,所以只能在linux的环境下使用。
makefile文件的执行方式是从下网上执行,所以最终生成的可执行文件的语句应该在文件的最上面。

一、常规编译c语言语句

编译单线程test.c文件

gcc test.c -o test

编译多线程test.c文件

gcc -pthread test.c -o test

如果是c++文件,把gcc用g++替换就可以编译。

二、初级使用Makefile

makefile的注释是#,同Python

1.在需要编译的项目的根目录下建立文件makefile

touch makefile

2.打开makefile

vim makefile

3.编写文件

一般格式:

目标文件: 依赖文件
(tab建)命令

比如编译上面的test.c文件

test: test.c
	gcc test.c -o test#此处要有回车

4.执行makefile

在当前目录输入make

make

三、进阶使用makefile

1.多个c文件需要编译为一个可执行文件

#将多个.o文件和main.c文件合并为一个可执行文件main
main: main.c foo.o bar.o tool.o
	gcc main.c foo.o bar.o tool.o -o main

#编译成foo.o文件
foo.o: foo.c
	gcc -c foo.c

#编译成bar.o文件
bar.o: bar.c
	gcc -c bar.c

#编译成tool.o文件
tool.o: tool.c
	gcc -c tool.c

2.编译完成后删除所有的.o文件

#将多个.o文件和main.c文件合并为一个可执行文件main
main: main.c foo.o bar.o tool.o
	gcc main.c foo.o bar.o tool.o -o main

#编译成foo.o文件
foo.o: foo.c
	gcc -c foo.c

#编译成bar.o文件
bar.o: bar.c
	gcc -c bar.c

#编译成tool.o文件
tool.o: tool.c
	gcc -c tool.c

#清除掉中间文件和编译结果
clean:
	rm *.o main

执行命令

make clean

3.定义变量

如果在makefile中多次使用到了一个指令,可以使用使用变量的方式来方便修改

使用方式
将gcc替换为CC

#定义变量
CC=gcc

#使用变量
test: test.c
	$(CC) test.c -o test

或者

#定义变量
CC=gcc
OPTIONS = -lm -g

#使用变量
test: test.c
	$(CC) $(OPTIONS) test.c -o test

4.同时编译多个可执行文件

如果test1.c和test2.c都有main函数的话,如果编译他们需要在makefile的最上面加一行语句

#定义变量
CC=gcc
OPTIONS = -lm -g

all: test1 test2
#使用变量
test1: test1.c
	$(CC) $(OPTIONS) test1.c -o test1


#使用变量
test2: test2.c
	$(CC) $(OPTIONS) test2.c -o test2

以上是关于Makefile常用写法的主要内容,如果未能解决你的问题,请参考以下文章

[Makefile]多目录Makefile写法

makefile的简单写法

多个文件目录下Makefile的写法

多个文件目录下Makefile的写法

大型工程多个目录下的Makefile写法

makefile文件写法解析