makefile $@, $^, $<, $? 轉

$@  表示目標文件
$^  表示所有的依賴文件
$<  表示第一個依賴文件
$?  表示比目標還要新的依賴文件列表

如一個目錄下有如下文件:

$ ls
hello.c  hi.c  main.c  Makefile
按照 Makefile 規則規規矩矩的寫:
main: main.o hello.o hi.o
        gcc -o main main.o hello.o hi.o

main.o: main.c
        cc -c main.c

hello.o: hello.c
        cc -c hello.c

hi.o: hi.c
        cc -c hi.c

clean:
        rm *.o
        rm main

改爲用上述符號進行替代:


main: main.o hello.o hi.o
        gcc -o $@ $^
main.o: main.c
        cc -c $<
hello.o: hello.c
        cc -c $<
hi.o: hi.c
        cc -c $<
clean:
        rm *.o
        rm main
        
 ===============================================================================       
$@表示目標,$^表示依賴列表
target:dependency1 dependency2
gcc -o $@ $^
$@ 就是target
$^ 就是dependency1 dependency2        

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章