OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5670|回复: 4

Makefile 自动变量问题 $^ $<

[复制链接]

1

主题

2

帖子

0

精华

新手入门

积分
10
金钱
10
注册时间
2019-10-28
在线时间
1 小时
发表于 2019-10-28 19:21:09 | 显示全部楼层 |阅读模式
1金钱
大家好,我在看裸机ledc 教程,看到Makefile  中 %.o:%.c
arm-linux-gnueabihf-ld-gcc -Wall -nostdlib -c -O2 -o $@ $<
请问 $<能否用$^替换?为什么?

最佳答案

查看完整内容[请看2#楼]

首先,$^:指所有的依赖文件 $@:指目标文件 $
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

37

主题

595

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1572
金钱
1572
注册时间
2017-7-17
在线时间
308 小时
发表于 2019-11-4 14:18:52 | 显示全部楼层
不能,$<表示的是第一个prerequisite,而$^会包含所有prerequisite。写规则的时候,往往是不需要把头文件一起写进去的,所以只需要一个.c就可以了,所以用$<,而不是$^。如果prerequiste只有一个,那$<和$^是一样的。
回复

使用道具 举报

6

主题

1127

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1656
金钱
1656
注册时间
2019-8-15
在线时间
102 小时
发表于 2019-10-28 19:21:10 | 显示全部楼层
首先,$^:指所有的依赖文件
          $@:指目标文件
          $<:指第一个依赖文件
附上网上的截图
          757({4O0QKCA593650~(1ZU.png
成功没有捷径
回复

使用道具 举报

0

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
80
金钱
80
注册时间
2019-10-28
在线时间
7 小时
发表于 2019-11-4 14:10:59 | 显示全部楼层
谢谢 顶一下
回复

使用道具 举报

1

主题

2

帖子

0

精华

新手入门

积分
10
金钱
10
注册时间
2019-10-28
在线时间
1 小时
 楼主| 发表于 2019-11-6 16:20:06 | 显示全部楼层

你说的比较有道理
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-23 04:48

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表