a: //目标名,(后面可以跟依赖名)
@echo "zurry"
@ls ./
@gcc main.c -o main
clean:
@rm -rf main
@echo "clean success!"
运行结果:
zurry
main.c Makefile
目标名后面可以跟依赖名,这样会先执行依赖目标的内容,再执行本目标的内容;
若只输入make并且没有跟目标名,则只输入排在第一位的目标名;
@可以抑制命令输出
如果不加@:
a: //目标名,(后面可以跟依赖名)
echo "zurry"
ls ./
gcc main.c -o main`在这里插入代码片`
clean:
rm -rf main
echo "clean success!"
运行结果:
echo "zurry"
zurry
ls ./
main main.c Makefile
gcc main.c -o main
则会输出执行的命令。
终端输入 make -n:
echo "zurry"
ls ./
gcc main.c -o main
只输出执行的命令,不输出结果
终端输入 make -s:
zurry
main main.c Makefile
终端输入 make -w:
make: Entering directory '/root/test/make'
echo "zurry"
zurry
ls ./
main main.c Makefile
gcc main.c -o main
make: Leaving directory '/root/test/make'
显示执行前执行后的路径;
make -C [dir]:指定makefile所在的目录
编译过程:
预处理: gcc -E main.cpp > main.ii
编译: gcc -S main.ii 生成 main.s的汇编文件
汇编: gcc -c main.s 生成 main.o(obj)的二进制文件
链接: gcc -lstdc++ main.o 得到名为a.out的可执行文件
本文介绍了Makefile的基本语法,包括目标依赖、命令抑制符@以及clean规则的使用。通过实例展示了如何编译C程序,详细阐述了预处理、编译、汇编和链接的步骤。同时,提到了make的-n、-s和-w选项的作用,以及make-C用于指定makefile所在目录的功能。

被折叠的 条评论
为什么被折叠?



