``当我使用make文件尝试使用我的应用程序时出现错误。这是我自己创建一个make文件的第一次尝试,我在网上发现了很多例子,但我不能让我的工作。我得到的错误,但是是一个编译错误,我手动编译,我不明白。错误是:
`dave@ubuntu:~/School/CS647/Programs/Homework4$ make
g++ -Wall -o StatWrapper StatWrapper.o tools.o
/usr/lib/gcc/x86_64-linux-gnu/4.6.1/../../../x86_64-linux-gnu/crt1.o: In function `_start':
(.text+0x20): undefined reference to `main'
collect2: ld returned 1 exit status
make: *** [StatWrapper] Error 1
` 这是我的make文件:
CC = g++
CFLAGS = -Wall
UTILDIR = ../../Utilities/
OBJECTS = Sweeper.o FileID.o P4Ford.o DirentWrapper.o StatWrapper.o tools.o
all: StatWrapper DirentWrapper FileID Sweeper P4Ford
#P4Ford: $(OBJECTS)
# $(CC) $(OBJECTS) -o P4Ford
DirentWrapper: DirentWrapper.o tools.o
$(CC) $(CFLAGS) -o DirentWrapper DirentWrapper.o tools.o
StatWrapper: StatWrapper.o tools.o
$(CC) $(CFLAGS) -o StatWrapper StatWrapper.o tools.o
P4Ford: P4Ford.o Sweeper.o
$(CC) $(CFLAGS) -o P4Ford P4Ford.o Sweeper.o
Sweeper: Sweeper.o FileID.o StatWrapper.o DirentWrapper.o tools.o
$(CC) $(CFLAGS) -o Sweeper Sweeper.o FileID.o StatWrapper.o DirentWrapper.o tools.o
FileID: FileID.o tools.o
$(CC) $(CFLAGS) -o FileID FileID.o tools.o
#tools: tools.o
# $(CC) $(CFLAGS) $(UTILDIR)tools.cpp
# dependencies ---------------------------------------------------
DirentWrapper.o: $(UTILDIR)DirentWrapper.cpp $(UTILDIR)DirentWrapper.hpp
StatWrapper.o: $(UTILDIR)StatWrapper.cpp $(UTILDIR)StatWrapper.hpp
P4Ford.o: P4Ford.cpp Sweeper.hpp
Sweeper.o: Sweeper.cpp FileID.hpp
FileID.o: FileID.cpp $(UTILDIR)tools.hpp
tools.o: $(UTILDIR)tools.cpp $(UTILDIR)tools.hpp
# cleanup
clean:
rm -f $(OBJECTS)
我认为这是我的make文件的问题,因为它在我手动编译时有效,但我无法确定。
提前致谢。
答案 0 :(得分:1)
只需将-c
添加到规则构建对象文件即可。如果没有这个,编译器会假定您正在创建一个需要定义main()
的可执行文件。 -c
标志表示尚未进行链接。
答案 1 :(得分:0)
StatWrapper: StatWrapper.o tools.o
$(CC) $(CFLAGS) -o StatWrapper StatWrapper.o tools.o
在此规则中,您要关联StatWrapper.o
和tools.o
并创建可执行文件StatWrapper
。这不起作用,因为它们都没有main
函数。
您需要删除所有这些无效规则,只留一个,这会将所有目标文件合并为一个可执行文件。
答案 2 :(得分:0)
让我们从一个目标文件开始。 Make有一个用于编译.cpp
文件的内置规则,但为了安全起见(以及练习),我们将编写一条规则:
Sweeper.o: Sweeper.cpp FileID.hpp
$(CC) $(CFLAGS) -c Sweeper.cpp -o Sweeper.o
在你走得更远之前测试一下。
我们在该规则中看到了一些冗余,因此我们将使用automatic variables对其进行一些清理:
Sweeper.o: Sweeper.cpp FileID.hpp
$(CC) $(CFLAGS) -c $< -o $@
在你走得更远之前测试一下。
请注意,该命令未明确提及Sweeper
。当我们为其他目标文件编写规则时,它们都将具有相同的命令。所以我们可以在static pattern rule:
OBJECTS = Sweeper.o FileID.o P4Ford.o DirentWrapper.o StatWrapper.o tools.o
DirentWrapper.o: $(UTILDIR)DirentWrapper.cpp $(UTILDIR)DirentWrapper.hpp
StatWrapper.o: $(UTILDIR)StatWrapper.cpp $(UTILDIR)StatWrapper.hpp
P4Ford.o: P4Ford.cpp Sweeper.hpp
Sweeper.o: Sweeper.cpp FileID.hpp
FileID.o: FileID.cpp $(UTILDIR)tools.hpp
tools.o: $(UTILDIR)tools.cpp $(UTILDIR)tools.hpp
$(OBJECTS) : %.o: %.cpp
$(CC) $(CFLAGS) -c $< -o $@
现在你应该能够,例如,make FileID.o
。
在你走得更远之前测试一下。
现在Make知道如何构建对象,我们只需要一条规则将它们链接到可执行文件中:
P4Ford: P4Ford.o Sweeper.o
$(CC) $(CFLAGS) $^ -o $@
如果您将此作为第一条规则,Make会将其视为默认值。 (你确定P4Ford
只需要那两个目标文件吗?也许它应该是P4Ford: $(OBJECTS)
。)