makefile中的变量,意外行为

Jen*_*nov 3 c gnu makefile working-set

我有makefile,我注意到一些特殊的东西.

在标有的行上<------,如果我把$(OBJECTS)而不是String.o编译失败.但我定义了OBJECTS=$(String.o),为什么这样做?

LIBS=-ldl $(OPTLIBS)
PREFIX?=string-automaton/
DESTDIR=/home/jenia/learn-c-the-hard-way/lib2/
CFLAGS=-g -O2 -Wall -Wextra -rdynamic -DNDEBUG -Llibstrl


OBJECTS=$(String.o)

TARGET=build/lib_String.a
SO_TARGET=$(patsubst %.a,%.so,$(TARGET))

# The Target Build
all: build $(TARGET) $(SO_TARGET) 

$(TARGET): CFLAGS += -fPIC
$(TARGET): $(OBJECTS) 
    ar rcs $@ $(OBJECTS)   
    ranlib $@

$(SO_TARGET): $(TARGET) $(OBJECTS)   
    $(CC) -shared -o $@  String.o     # <----------- $(OBJECTS) woud fail

build:
    @mkdir -p build
    @mkdir -p bin

clean:
    rm -rf build $(OBJECTS) $(TESTS)
    rm -f tests/tests.log
    find . -name "*.gc*" -exec rm {} \;
    rm -rf `find . -name "*.dSYM" -print`

# The Install
install: all
    install -d $(DESTDIR)/$(PREFIX)/lib/
    install $(TARGET) $(DESTDIR)/$(PREFIX)/lib/
Run Code Online (Sandbox Code Playgroud)

此外,作为一个后续问题,如果我添加$(OBJECTS)到该行<-----$(OBJECTS)从它之前的行中删除然后它编译.像这样:

$(SO_TARGET): $(TARGET) 
$(CC) -shared -o $@ $(OBJECTS)    
Run Code Online (Sandbox Code Playgroud)

那么有人可以回答我为什么$(OBJECTS)不解决String.o上线<-----

谢谢

Mik*_*CAT 6

这是因为$(String.o)将解析为另一个字符串 - 如果String.o未定义,可能是空字符串.

我想你应该更换

OBJECTS=$(String.o)
Run Code Online (Sandbox Code Playgroud)

OBJECTS=String.o
Run Code Online (Sandbox Code Playgroud)