我是靠谱客的博主 隐形小海豚,最近开发中收集的这篇文章主要介绍Makefile的call函数,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

http://blog.csdn.net/codesinger/article/details/9316251


写了个例子来研究Makefile的call函数:

[plain]  view plain copy
  1. #define a multiline variable  
  2. define target   
  3.     echo $@  
  4.     echo $@  
  5. endef  
  6.   
  7. #define the target which is the first target, so default target  
  8. all:  
  9.     $(call target,all)  
  10.   
  11. #define the second target, we must explicitly make it  
  12. clean:  
  13.     $(call target,clean)      
  14.   
  15. #declare that all and clean are phony targets  
  16. .PHONY: all clean  

执行make或make all的结果是:

[plain]  view plain copy
  1. echo all  
  2. all  
  3. echo all  
  4. all  


执行make clean的结果是:

[plain]  view plain copy
  1. echo clean  
  2. clean  
  3. echo clean    
  4. clean  

其实源代码可以这么写的:

[plain]  view plain copy
  1. #define a multiline variable  
  2. define target   
  3.     echo $@  
  4.     echo $@  
  5. endef  
  6.   
  7. #define the target which is the first target, so default target  
  8. all:  
  9.     $(call target)  
  10.   
  11. #define the second target, we must explicitly make it  
  12. clean:  
  13.     $(call target)    
  14.   
  15. #declare that all and clean are phony targets  
  16. .PHONY: all clean  

结果跟上面一样。


小结:Makefile中的第一个目标是最终目标,是make默认执行的目标,call函数会以此调用多行变量的每一个(此处是make命令,所以会被执行了)。然后$@自动化变量在make执行是会被赋值为当前的目标。



最后

以上就是隐形小海豚为你收集整理的Makefile的call函数的全部内容,希望文章能够帮你解决Makefile的call函数所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部