这在翻译中有点丢失,所以我要更准确地说:我们有类 recursion.c、fib.c 和 countUp.c。从 recursion.c 我们必须递归调用 fib.c 或 countUp.c,由输入参数决定。我不能使用头文件,只能放置原型:
int fib(int n);
和
void countUp(int n);
我的 Makefile
TAR = tar
COMPILER_FLAGS = -g -Wall -std=c99 -c
LINKER_FLAGS = -g -o
OBJS = recurse.o
C_FILES = recurse.c fib.c countUp.c
ASM_FILES = recurse.asm
TARGET_FILE = recurse
TARGET_TAR = PA5.tar
$(TARGET_TAR): $(TARGET_FILE)
$(TAR) -cvf $(TARGET_TAR) $(C_FILES) $(ASM_FILES) $(TARGET_FILE) Makefi$
recurse.o: recurse.c
$(C_COMPILER) $(COMPILER_FLAGS) $(C_FILES)
$(TARGET_FILE): $(OBJS)
$(LD_LINKER) $(LINKER_FLAGS) $(TARGET_FILE) $(OBJS)
其中 fib 和 countUp 类方法必须递归调用。recursive.c 文件被认为是我们的 c 驱动程序。不要创建或实现除标准 c 头文件(stdio.h、string.h 等)之外的任何头文件。当我尝试运行它时,我得到:
make
gcc -g -o recurse recurse.o
recurse.o: In function `main':
(file root location)/recurse.c:43: undefined reference to `fib'
(file root location)/recurse.c:46: undefined reference to `countUp'
collect2: ld returned 1 exit status
make: *** [recurse] Error 1
任何线索发生了什么。
原始问题:我有多个 C 文件,我将它们组合成一个可执行文件。例如说我有 math.c,参数被传递给它,然后如果输入参数调用 add 它执行 add.c 中的函数,如果参数调用 subtract 它将调用 subtract.c 中的函数等。文件然后编译成 .o 文件,然后创建一个可执行文件。我遇到的问题是无法使用标头 (.h) 文件。有什么办法可以闯入单独的班级还是我错过了什么?我真的不知道如何问这个问题,就 C 而言,行话很糟糕,对不起:(
我想我真的不明白司机的想法。(不是设备驱动程序,她一直告诉我们这是 ac 可执行驱动程序)。