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常用写法的主要内容,如果未能解决你的问题,请参考以下文章