makefile中关于all和.PHONY .cpp.o
2015-07-12 20:41
477 查看
转自:http://blog.163.com/benben_long/blog/static/199458243201110230292490/
http://blog.csdn.net/wangxmin2005/article/details/8082409
请编写一个makefile同时编译、链接下面两个程序:
main1.c:
#include<stdio.h>
int main(void)
{
printf("main1\n");
}
main2.c:
#include<stdio.h>
int main(void)
{
printf("main2\n");
}
【分析】:这里需要生成两个可执行文件main1和main2(两个目标)。由于makefile只能有一个目标,所以可以构造一个没有规则的终极目标all,并以这两个可执行文件作为依赖。如下:
makefile:
all:main1 main2
main1: main1.c
@gcc main1.c -o main1
main2: main2.c
@gcc main2.c -o main2
很多时候我们在执行make时会产生许多过程文件,比如将上面的makefile改为:
makefile:
all:main1 main2
main1: main1.c
@gcc main1.c -o main1
main2: main2.o
@gcc main2.o -o main2
main2.o: main2.c
@gcc -c main2.c
这样就会生成一个我们不需要的过程文件main2.o。
如果希望将生成的过程文件删掉,根据前面再增加一个目标clean:
all:main1 main2 clean
main1: main1.c
@gcc main1.c -o main1
main2: main2.o
@gcc main2.o -o main2
main2.o: main2.c
@gcc -c main2.c
clean:
@rm -f main2.o
但是当我们make之后main2.o仍然存在,怎么回事呢
原来这里的目标clean没有任何依赖,make执行时认为这已经到“根上”了(就是认为磁盘上有clean,就像main2.c),将其忽略(尽管它有规则)。
关键字.PHONY可以解决这问题,告诉make该目标是“假的”(磁盘上其实没有clean),这时make为生成这个目标就会将其规则执行一次。.PHONY修饰的目标就是只有规则没有依赖。
加上一句.PHONY:clean即可:
all:main1 main2 clean
main1: main1.c
@gcc main1.c -o main1
main2: main2.o
@gcc main2.o -o main2
main2.o: main2.c
@gcc -c main2.c
.PHONY:clean
clean:
@rm -f main2.o
【附】
phony ['f?uni] a. 假的
GNU的make能够使整个软件工程的编译、链接只需要一个命令就可以完成。
makefile的术语:
规则:用于说明如何生成一个或多个目标文件
规则的格式:
targets:prerequisites
command
目标: 依赖
命令
+++++命令需要以[TAB]键开始++++
补充:
.cpp.o:
$(CC) $(INCLUDE) $(CFLAGS) -c $<
这里.cpp.o是老式的“后缀规则”,编译器将会自动将.cpp识别为源文件后缀,而.o识别为输出文件后缀。特别需要注意的是,后缀规则不允许任何依赖文件,但也不能没有命令。
http://blog.csdn.net/wangxmin2005/article/details/8082409
请编写一个makefile同时编译、链接下面两个程序:
main1.c:
#include<stdio.h>
int main(void)
{
printf("main1\n");
}
main2.c:
#include<stdio.h>
int main(void)
{
printf("main2\n");
}
【分析】:这里需要生成两个可执行文件main1和main2(两个目标)。由于makefile只能有一个目标,所以可以构造一个没有规则的终极目标all,并以这两个可执行文件作为依赖。如下:
makefile:
all:main1 main2
main1: main1.c
@gcc main1.c -o main1
main2: main2.c
@gcc main2.c -o main2
很多时候我们在执行make时会产生许多过程文件,比如将上面的makefile改为:
makefile:
all:main1 main2
main1: main1.c
@gcc main1.c -o main1
main2: main2.o
@gcc main2.o -o main2
main2.o: main2.c
@gcc -c main2.c
这样就会生成一个我们不需要的过程文件main2.o。
如果希望将生成的过程文件删掉,根据前面再增加一个目标clean:
all:main1 main2 clean
main1: main1.c
@gcc main1.c -o main1
main2: main2.o
@gcc main2.o -o main2
main2.o: main2.c
@gcc -c main2.c
clean:
@rm -f main2.o
但是当我们make之后main2.o仍然存在,怎么回事呢
原来这里的目标clean没有任何依赖,make执行时认为这已经到“根上”了(就是认为磁盘上有clean,就像main2.c),将其忽略(尽管它有规则)。
关键字.PHONY可以解决这问题,告诉make该目标是“假的”(磁盘上其实没有clean),这时make为生成这个目标就会将其规则执行一次。.PHONY修饰的目标就是只有规则没有依赖。
加上一句.PHONY:clean即可:
all:main1 main2 clean
main1: main1.c
@gcc main1.c -o main1
main2: main2.o
@gcc main2.o -o main2
main2.o: main2.c
@gcc -c main2.c
.PHONY:clean
clean:
@rm -f main2.o
【附】
phony ['f?uni] a. 假的
GNU的make能够使整个软件工程的编译、链接只需要一个命令就可以完成。
makefile的术语:
规则:用于说明如何生成一个或多个目标文件
规则的格式:
targets:prerequisites
command
目标: 依赖
命令
+++++命令需要以[TAB]键开始++++
补充:
.cpp.o:
$(CC) $(INCLUDE) $(CFLAGS) -c $<
这里.cpp.o是老式的“后缀规则”,编译器将会自动将.cpp识别为源文件后缀,而.o识别为输出文件后缀。特别需要注意的是,后缀规则不允许任何依赖文件,但也不能没有命令。
相关文章推荐
- dev c++ Boost库的安装
- The key of C Language
- 二叉搜索树C++实现
- 【S6】当心C++编译器最烦人的分析机制
- C语言中的strlen实现方法
- 【C++11】新特性——引入nullprt
- 一个简单链表的C++实现(二)
- int和long int为什么字节数是一样的?
- C++类型转换之static_cast, dynamic_cast, reinterpret_cast, const_cast探讨
- c++学习-特殊类成员
- C++对象模型(很详细)
- C++新特性学习(1)
- 操作系统-信号量C++代码WIN32
- c++ 容器基本方法
- C++ : 引用的实质理解 !!!!
- c++引用与指针的区别(着重理解)
- C&C++函数指针
- 移动开发、C/C++、算法、程序员人生
- Kth Smallest Element in a BST
- Palindrome Linked List