• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            六、多目標

            Makefile的規則中的目標可以不止一個,其支持多目標,有可能我們的多個目標同時依賴于一個文件,并且其生成的命令大體類似。于是我們就能把其合并起來。當然,多個目標的生成規則的執行命令是同一個,這可能會可我們帶來麻煩,不過好在我們的可以使用一個自動化變量“$@”(關于自動化變量,將在后面講述),這個變量表示著目前規則中所有的目標的集合,這樣說可能很抽象,還是看一個例子吧。

                bigoutput littleoutput : text.g
                        generate text.g -$(subst output,,$@) >; $@

                上述規則等價于:

                bigoutput : text.g
                        generate text.g -big >; bigoutput
                littleoutput : text.g
                        generate text.g -little >; littleoutput

                其中,-$(subst output,,$@)中的“$”表示執行一個Makefile的函數,函數名為subst,后面的為參數。關于函數,將在后面講述。這里的這個函數是截取字符串的意思,“$@”表示目標的集合,就像一個數組,“$@”依次取出目標,并執于命令。


            七、靜態模式

            靜態模式可以更加容易地定義多目標的規則,可以讓我們的規則變得更加的有彈性和靈活。我們還是先來看一下語法:

                <targets ...>;: <target-pattern>;: <prereq-patterns ...>;
                        <commands>;
                        ...


                targets定義了一系列的目標文件,可以有通配符。是目標的一個集合。

                target-parrtern是指明了targets的模式,也就是的目標集模式。

                prereq-parrterns是目標的依賴模式,它對target-parrtern形成的模式再進行一次依賴目標的定義。

            這樣描述這三個東西,可能還是沒有說清楚,還是舉個例子來說明一下吧。如果我們的<target-parrtern>;定義成“%.o”,意思是我們的<target>;集合中都是以“.o”結尾的,而如果我們的<prereq-parrterns>;定義成“%.c”,意思是對<target-parrtern>;所形成的目標集進行二次定義,其計算方法是,取<target-parrtern>;模式中的“%”(也就是去掉了[.o]這個結尾),并為其加上[.c]這個結尾,形成的新集合。

            所以,我們的“目標模式”或是“依賴模式”中都應該有“%”這個字符,如果你的文件名中有“%”那么你可以使用反斜杠“\”進行轉義,來標明真實的“%”字符。

            看一個例子:

                objects = foo.o bar.o

                all: $(objects)

                $(objects): %.o: %.c
                        $(CC) -c $(CFLAGS) $< -o $@


            上面的例子中,指明了我們的目標從$object中獲取,“%.o”表明要所有以“.o”結尾的目標,也就是“foo.o bar.o”,也就是變量$object集合的模式,而依賴模式“%.c”則取模式“%.o”的“%”,也就是“foo bar”,并為其加下“.c”的后綴,于是,我們的依賴目標就是“foo.c bar.c”。而命令中的“$<”和“$@”則是自動化變量,“$<”表示所有的依賴目標集(也就是“foo.c bar.c”),“$@”表示目標集(也就是“foo.o bar.o”)。于是,上面的規則展開后等價于下面的規則:

                foo.o : foo.c
                        $(CC) -c $(CFLAGS) foo.c -o foo.o
                bar.o : bar.c
                        $(CC) -c $(CFLAGS) bar.c -o bar.o

            試想,如果我們的“%.o”有幾百個,那種我們只要用這種很簡單的“靜態模式規則”就可以寫完一堆規則,實在是太有效率了。“靜態模式規則”的用法很靈活,如果用得好,那會一個很強大的功能。再看一個例子:


                files = foo.elc bar.o lose.o

                $(filter %.o,$(files)): %.o: %.c
                        $(CC) -c $(CFLAGS) $< -o $@
                $(filter %.elc,$(files)): %.elc: %.el
                        emacs -f batch-byte-compile $<


            $(filter %.o,$(files))表示調用Makefile的filter函數,過濾“$filter”集,只要其中模式為“%.o”的內容。其的它內容,我就不用多說了吧。這個例字展示了Makefile中更大的彈性。
            Posted on 2007-04-17 11:00 艾凡赫 閱讀(3385) 評論(0)  編輯 收藏 引用 所屬分類: C++
            久久亚洲国产午夜精品理论片| 热久久这里只有精品| 麻豆久久久9性大片| 亚洲综合精品香蕉久久网97 | 精品视频久久久久| 91久久精品视频| 久久精品国产亚洲av日韩| 亚洲欧美久久久久9999| 久久亚洲精品视频| 2020最新久久久视精品爱| 久久久久亚洲AV无码去区首| 思思久久99热只有频精品66| 久久婷婷人人澡人人爽人人爱| 久久久久久精品无码人妻| 久久99国产综合精品免费| 国产精品久久久久jk制服| 国产无套内射久久久国产| 亚洲精品NV久久久久久久久久 | 久久综合久久伊人| 久久婷婷五月综合成人D啪| 日本国产精品久久| 精品一区二区久久久久久久网站| 欧美久久一区二区三区| 亚洲精品乱码久久久久久久久久久久 | 99久久99这里只有免费的精品| 93精91精品国产综合久久香蕉| 久久精品人人做人人爽电影| 久久93精品国产91久久综合| 人人狠狠综合久久亚洲婷婷| 人妻无码αv中文字幕久久| 久久久久久午夜精品| 久久亚洲国产精品一区二区| 久久精品国产一区| 国产欧美一区二区久久| 久久亚洲AV成人无码电影| 亚洲午夜无码久久久久| 国产成人无码精品久久久性色| 伊人久久五月天| 新狼窝色AV性久久久久久| 亚洲国产精品成人久久| 久久夜色精品国产网站|