makefile中关于all和.PHONY .cpp.o

转自: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");

}

【分析】:这里需要生成两个可执行文件main1main2(两个目标)。由于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仍然存在,怎么回事呢makefile中的all和.PHONY的作用

原来这里的目标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的术语:

规则:用于说明如何生成一个或多个目标文件

规则的格式:

targetsprerequisites

    command

目标: 依赖

    命令

+++++命令需要以[TAB]键开始++++


补充:

.cpp.o:

    $(CC) $(INCLUDE) $(CFLAGS) -c $<

这里.cpp.o是老式的“后缀规则”,编译器将会自动将.cpp识别为源文件后缀,而.o识别为输出文件后缀。特别需要注意的是,后缀规则不允许任何依赖文件,但也不能没有命令。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个针对 Windows 平台的 Makefile 文件,用于编译 Project2 项目。 以下是逐行解释: ```makefile # Project: Project2 ``` 注释,表示这个 Makefile 是为编译 Project2 项目而创建的。 ```makefile CPP = g++.exe CC = gcc.exe WINDRES = windres.exe ``` 定义了三个变量,分别用于指定 C++ 编译器、C 编译器和 Windows 资源编译器。 ```makefile OBJ = main.o visual.o menu.o map.o end.o LINKOBJ = main.o visual.o menu.o map.o end.o ``` 定义了两个变量,分别用于指定编译后生成的目标文件和链接需要的目标文件。 ```makefile LIBS = -L"C:/Program Files (x86)/Dev-Cpp/MinGW32/lib" -L"C:/Program Files (x86)/Dev-Cpp/MinGW32/mingw32/lib" -static-libstdc++ -static-libgcc INCS = -I"C:/Program Files (x86)/Dev-Cpp/MinGW32/include" CXXINCS = -I"C:/Program Files (x86)/Dev-Cpp/MinGW32/include" -I"C:/Program Files (x86)/Dev-Cpp/MinGW32/lib/gcc/mingw32/4.7.2/include/c++" ``` 定义了三个变量,分别用于指定需要链接的库文件、需要包含的头文件路径和 C++ 编译器需要包含的头文件路径。 ```makefile BIN = mimigong.exe ``` 定义了一个变量,用于指定生成的可执行文件名。 ```makefile CXXFLAGS = $(CXXINCS) CFLAGS = $(INCS) ``` 定义了两个变量,分别用于指定 C++ 编译器和 C 编译器的编译选项。 ```makefile RM = rm -f ``` 定义了一个变量,用于指定删除文件的命令。 ```makefile .PHONY: all all-before all-after clean clean-custom ``` 指定了一些伪目标,分别是 all、all-before、all-after、clean 和 clean-custom。 ```makefile all: all-before $(BIN) all-after ``` 定义了 all 目标,表示执行 all-before、$(BIN) 和 all-after 三个目标。 ```makefile clean: clean-custom ${RM} $(OBJ) $(BIN) ``` 定义了 clean 目标,表示执行 clean-custom 目标,然后删除生成的目标文件和可执行文件。 ```makefile $(BIN): $(OBJ) $(CPP) $(LINKOBJ) -o $(BIN) $(LIBS) ``` 定义了 $(BIN) 目标,表示需要通过链接 $(OBJ) 目标生成 $(BIN) 可执行文件。 ```makefile main.o: main.c $(CPP) -c main.c -o main.o $(CXXFLAGS) visual.o: visual.c $(CPP) -c visual.c -o visual.o $(CXXFLAGS) menu.o: menu.c $(CPP) -c menu.c -o menu.o $(CXXFLAGS) map.o: map.c $(CPP) -c map.c -o map.o $(CXXFLAGS) end.o: end.c $(CPP) -c end.c -o end.o $(CXXFLAGS) ``` 分别定义了 main.o、visual.o、menu.o、map.o、end.o 五个目标,用于编译对应的源代码文件,并将编译后生成的目标文件保存在当前目录下。其,-c 选项表示只编译,不链接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值