9

我正在尝试使用 make 编译我的一段代码。通常我编译我的代码是这样的:

mipsisa32r2el-timesys-linux-gnu-g++ -o testing -I/usr/include/libxml2 -L/develop/xc4/rootfs/parsecpp/lib -L/develop/xc4/rootfs/parsecpp/sqlite-mips2/lib -I/develop/xc4/rootfs/parsecpp/sqlite-mips2/include db.cpp main.cpp networkinterfacemodule.cpp network.cpp multiplex.cpp program.cpp service.cpp -lsqlite3 -lxml2

为了摆脱这个长命令,我尝试编写一个 makefile:

CC= mipsisa32r2el-timesys-linux-gnu-g++

export LD_LIBRARY_PATH=:/parsecpp/sqlite-mips2/lib:/parsecpp/lib:/tmp/vixs_temp/DirectFB/single_core/lib


CFLAGS=-I/usr/include/libxml2 -I/develop/xc4/rootfs/parsecpp/sqlite-mips2/include

LDFLAGS=-L/develop/xc4/rootfs/parsecpp/lib -L/develop/xc4/rootfs/parsecpp/sqlite-mips2/lib

LIBS = -lsqlite3 -lxml2

PROG=testing

all: main.o db.o mod.o multiplex.o network.o networkinterfacemodule.o program.o service.o
    $(CC) -o $(PROG) $(CFLAGS) $(LDFLAGS)  main.o db.o mod.o multiplex.o network.o networkinterfacemodule.o program.o service.o $(LIBS) 

main.o: main.cpp 
    $(CC) $(CFLAGS) $(LDFLAGS) main.cpp db.cpp networkinterfacemodule.cpp mod.cpp multiplex.cpp network.cpp program.cpp service.cpp $(LIBS)

db.o: db.cpp 
    $(CC) $(CFLAGS) $(LDFLAGS) db.cpp $(LIBS)


mod.o: mod.cpp
    $(CC) $(CFLAGS) $(LDFLAGS) mod.cpp $(LIBS)

multiplex.o: multiplex.cpp
    $(CC) $(CFLAGS) $(LDFLAGS) multiplex.cpp $(LIBS)

network.o: network.cpp
    $(CC) $(CFLAGS) $(LDFLAGS) network.cpp $(LIBS)

networkmoduleinterface.o: networkinterfacemodule.cpp
    $(CC) $(CFLAGS) $(LDFLAGS) networkinterfacemodule.cpp $(LIBS)

program.o: program.cpp
    $(CC) $(CFLAGS) $(LDFLAGS) program.cpp $(LIBS)

service.o: service.cpp
    $(CC) $(CFLAGS) $(LDFLAGS) service.cpp $(LIBS)

clean:
    rm -rf *o testing

然后我得到这个错误:

/opt/timesys/linux-gnu/toolchain/bin/../../toolchain/lib/crt1.o: In function `__start':
(.text+0xc): undefined reference to `main'
/opt/timesys/linux-gnu/toolchain/bin/../../toolchain/lib/crt1.o: In function `__start':
(.text+0x10): undefined reference to `main'
collect2: ld returned 1 exit status
make: *** [db.o] Error 1

有谁能够帮助我?

4

3 回答 3

25

每当您只是编译文件而不链接它时,请使用“-c”标志。

例如 :-

db.o: db.cpp 
$(CC) -c $(CFLAGS) $(LDFLAGS) db.cpp $(LIBS)

此外,在编译时,无需向编译器提供“$(LIBS)”,只需在链接时提供。您也不需要链接器标志,因为使用“-c”标志时不会调用链接器。

所以你可以写,

 db.o: db.cpp 
 $(CC) -c $(CFLAGS) db.cpp

更新(基于评论): -

链接文件时,链接器需要一个且只有一个main函数。在上述情况下,主函数未定义db.cpp,因此尽管编译成功,但链接器会抛出错误,因为它找不到该main函数。

于 2012-06-27T11:30:20.373 回答
3

当您在没有 -c 标志的情况下进行编译时,gcc 会尝试链接程序。由于 main 函数很可能在 main.c 而不是 db.c 中,因此在 db.c 中搜索 main 函数时,链接器会失败。这意味着您需要告诉编译器您只想要尚未链接但翻译成目标文件的输出,这正是 -c 标志所做的。

这导致了 rajatkhanduja 所说的:

db.o: db.cpp 
$(CC) -c $(CFLAGS) db.cpp
于 2012-06-27T11:38:06.363 回答
0

我猜你错过了链接规则。

你应该有第一条规则告诉 make 如何链接:

testing_OBJECTS = main.o db.o mod.o multiplex.o network.o networkinterfacemodule.o program.o service.o

testing$(EXEEXT): $(testing_OBJECTS)
    ld $(testing_OBJECTS) $(LDFLAGS) $(LIBS)

并且规则必须是以下条件的先决条件all

all: testing$(EXEEXT)

此外,由于您所有的“*.o: *.cpp”规则都是相同的,您可以指定一个规则并让make您替换文件名。询问您是否需要更多数据。

于 2012-06-27T11:41:40.420 回答