文章标题

xiaoxiao2021-02-28  124

专题1:Makefile工程管理

<div class="article_manage clearfix"> <div class="article_l"> <span class="link_categories"> 标签: <a href="http://www.csdn.net/tag/makefile" target="_blank" onclick="_gaq.push(['_trackEvent','function', 'onclick', 'blog_articles_tag']);">makefile</a> </span> </div> <div class="article_r"> <span class="link_postdate">2016-12-17 15:26</span> <span class="link_view" title="阅读次数">79人阅读</span> <span class="link_comments" title="评论次数"> <a href="#comments" onclick="_gaq.push(['_trackEvent','function', 'onclick', 'blog_articles_pinglun'])">评论</a>(0)</span> <span class="link_collect tracking-ad" data-mod="popu_171"> <a href="javascript:void(0);" onclick="javascript:collectArticle('专题1:Makefile工程管理','53707915');return false;" title="收藏" target="_blank">收藏</a></span> <span class="link_report"> <a href="#report" onclick="javascript:report(53707915,2);return false;" title="举报">举报</a></span> </div> </div> <style type="text/css"> .embody{ padding:10px 10px 10px; margin:0 -20px; border-bottom:solid 1px #ededed; } .embody_b{ margin:0 ; padding:10px 0; } .embody .embody_t,.embody .embody_c{ display: inline-block; margin-right:10px; } .embody_t{ font-size: 12px; color:#999; } .embody_c{ font-size: 12px; } .embody_c img,.embody_c em{ display: inline-block; vertical-align: middle; } .embody_c img{ width:30px; height:30px; } .embody_c em{ margin: 0 20px 0 10px; color:#333; font-style: normal; } </style> <script type="text/javascript"> $(function () { try { var lib = eval("("+$("#lib").attr("value")+")"); var html = ""; if (lib.err == 0) { $.each(lib.data, function (i) { var obj = lib.data[i]; //html += '<img src="' + obj.logo + '"/>' + obj.name + "  "; html += ' <a href="' + obj.url + '" target="_blank">'; html += ' <img src="' + obj.logo + '">'; html += ' <em><b>' + obj.name + '</b></em>'; html += ' </a>'; }); if (html != "") { setTimeout(function () { $("#lib").html(html); $("#embody").show(); }, 100); } } } catch (err) { } }); </script> <div class="category clearfix"> <div class="category_l"> <img src="http://static.blog.csdn.net/images/category_icon.jpg"> <span>分类:</span> </div> <div class="category_r"> <label onclick="GetCategoryArticles('6571647','lvjianxin6015','top','53707915');"> <span onclick="_gaq.push(['_trackEvent','function', 'onclick', 'blog_articles_fenlei']);">嵌入式技术<em>(26)</em></span> <img class="arrow-down" src="http://static.blog.csdn.net/images/arrow_triangle _down.jpg" style="display:inline;"> <img class="arrow-up" src="http://static.blog.csdn.net/images/arrow_triangle_up.jpg" style="display:none;"> <div class="subItem"> <div class="subItem_t"><a href="http://blog.csdn.net/lvjianxin6015/article/category/6571647" target="_blank">作者同类文章</a><i class="J_close">X</i></div> <ul class="subItem_l" id="top_6571647"> </ul> </div> </label> </div> </div> <div class="bog_copyright"> <p class="copyright_p">版权声明:本文为博主原创文章,未经博主允许不得转载。</p> </div>

1、为什么要使用Makefile?(一劳永逸)

2、Makefile构成 1)规则:用于说明如何生成目标文件,规则的格式如下: targets:prerequisites [TAB]command 目标 依赖 命令(可以有多个依赖和命令,也可以有多个规则,但同一个规则只有一个目标) 特别提示:命令前需要使用【TAB】键隔开 例如:

all: led.o arm-linux-ld -Tled.lds -o led.elf led.o arm-linux-objcopy -O binary led.elf led.bin led.o : led.S arm-linux-gcc -g -o led.o -c led.S .PHONY: clean clean: rm *.o led.elf led.bin 12345678910 12345678910

2)伪目标(没有依赖) 关键字:.PHONY 例如:(伪目标完成清理工作)

.PHONY: clean clean: rm *.o led.elf led.bin 123 123

3)最终目标 第一条规则的目标就是最终目标,上面的all就是最终目标。 规则执行顺序(根据依赖文件):

make后面可以接上依赖文件,只执行这个依赖文件的规则。然后再使用make就执行其他剩余的规则。

4)变量(起一个简化的作用) (1)在同一个makefile中,多次出现同样的文件,可以使用变量代替: 注意obj变量可以随便定义,但左右两边不能有空格。在使用这个变量的时候,有特定的格式,用符号$。如上图。 (2)在makefile中,用户除了可以自己定义变量外,还可以使用系统中已经定义好的默认变量。

5)通用规则 当一个makefile中有许多类似的规则时,如果将这些规则合并为一条通用规则?

修改之前:

修改之后:(用%代替)

3、makefile使用技巧 1)去回显 红方框中就是回显: 去掉方法:在对应的命令前加一个@。

2)更改Makefile的名字 [root@local lesson1]# mv Makefile makefile(大写的M和小写的m,make都能默认执行) [root@local lesson1]# mv Makefile file(如果改为file,make不能识别,能识别的方法就是叫上 -f file)

(function () {('pre.prettyprint code').each(function () { var lines = (this).text().split(\n).length;var numbering = $(' ').addClass('pre-numbering').hide(); (this).addClass(hasnumbering).parent().append( numbering); for (i = 1; i
转载请注明原文地址: https://www.6miu.com/read-30199.html

最新回复(0)