[求助] Makefile文件的问题

chenbingjy   2016-9-19 13:18 楼主
有一个工程的文件列表如下。工程中共有5个文件,在add目录中有add_int.c和add_float.c,两个文件分别计算整形和浮点型的相加;在sub目录下有文件 sub_int.c和sub_float.c,分别计算整形和浮点型的相减;顶层目录有main.c 文件负责整个程序。 工程中的代码分别存放在add/add_int.c,add/add_float.c,add/add.h,sub/sub_int.c sub/sub_float.c,sub/sub.h和main.c中。 其中,在Makefile文件中,main.o规则的书写方式如下: main.o:main.c add/add.h sub/sub.h gcc -c -o main.o main.c -Iadd -Isub 有一种简便的方法可以实现与上面相同的功能: main.o:%o:%c gcc -c $< -o $@ 这种方法的规则main.o中依赖项中的“%o:%c"的作用是将TARGET域的.o的扩展 名替换为.c,即将main.o替换为main.c。而命令行的$<表示依赖项的结果,即main.c; $@ 表示TARGET域的名称,即main.o 其中,有一个Makefile文件如下: 3.jpg 编译: 4.jpg 其中,mkdir -p ./$@ 这句我不懂。书上说,$@ 是目标项中目标文件的名称。 那为什么这个$@ 表示objs呢?谢谢 本帖最后由 chenbingjy 于 2016-9-19 13:28 编辑
为江山踏坏了乌骓马,为社稷拉断了宝雕弓。

回复评论 (1)

我好像明白了。因为前面有$(OBJSDIR).
为江山踏坏了乌骓马,为社稷拉断了宝雕弓。
点赞  2016-9-19 13:29
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复