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 $<



 

你可能感兴趣的:(makefile)