makefile中g++ -o -c參數解釋

 

CC = g++

SRCS = $(wildcard *.cpp)

OBJS = $(patsubst %cpp, %o, $(SRCS))

LDFLAGS :=-lsqlite3 -lTR3A

CFLAGS := -Wall -O2 -g -L/home/usr

INCLUDE = -I ./com/inc \
        -I ./com/lib/inc
CFLAGS += $(INCLUDE)

TARGET = TEST

all : $(TARGET)

$(TARGET):$(OBJS)
    $(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS) 
%.o:%.c
    $(CC) $(CFLAGS) -o $@ -c $< $(LDFLAGS)


解釋(更新中):
    $(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS)   
    (1)-o $@ 與 $^各爲一個整體,語句不存在-c,就決定了這行命令是編譯,鏈接過程,
-o後面的$@代表鏈接後生成的可執行文件的取名,你可以TARGET = main.o,但是main.o代
表的是可執行文件,只是後綴名爲.o的可執行文件,而不是編譯生成的.o文件,你也可以去掉
-o $@,則鏈接器自動生成名爲a.out的可執行文件。
    $(CC) $(CFLAGS) -o $@ -c $< $(LDFLAGS)  
    (2)-o $@ 與 -c $<各爲一個整體,語句中有-c存在,就決定了這行命令只編譯不鏈接,
-o $@代表指定編譯生成的.o按照$@取名,而$@本身代表編譯後生成的.o,所以可以省略-o $@。

疑問:關於-o -c $(CFLAGS)在命令中的位置關係
    如下三種情況等價
    (1)$(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS)
    (2)$(CC) $(CFLAGS) $^ -o $@ $(LDFLAGS)
    (3)$(CC) $^ -o $@ $(LDFLAGS) $(CFLAGS) 


    $(CC) $(CFLAGS) -o $@ -c $< $(LDFLAGS) 等價於 $(CC) $(CFLAGS) -o $@ -c $<



 

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