• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

SOC/IP验证工程师

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

makefile中关于all和.PHONY

请编写一个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]键开始

posted on 2023-06-03 19:16  SOC验证工程师  阅读(52)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3