我究竟如何使用makefile?

时间:2009-12-03 06:26:00

标签: c makefile

此刻我真的很困惑。

所以我有5个文件:main.c,flight.c,flight.h,passenger.c和passenger.h

flight.h包含flight.c的函数原型,passenger.h具有passenger.c的函数原型

flight.c和passenger.c有这些功能的定义。

main.c是我将与之交互的程序,从两个.c文件中调用函数

我不确定.o文件的用途是什么,请有人解释一下吗?这是我的Makefile:

flight.o: flight.c flight.h
    gcc -Wall -g -c flight.c    
passenger.o: passenger.c passenger.o
    gcc -Wall -g -c passenger.c    
main.o: main.c
    gcc -Wall -g -c main.c     
reservations.out: main.o flight.o passenger.o
    gcc -Wall -g flight.o passenger.o main.o -o reservations.out

编辑:然后我使用命令“make Makefile”,并得到一个错误:make:没有为'Makefile'做任何事。

在我的文件中,gcc之前有一个标签。 我很感激任何帮助,我确信有很多事情我做错了。感谢。

3 个答案:

答案 0 :(得分:10)

你的问题是你使用了错误的命令。我将以下行添加到makefile的顶部:

all: reservations.out

然后只需在命令行输入make即可。如果您不想编辑该文件,只需使用make reservations.out即可获得正确的行为。

关于.o文件是什么:它是一个'对象'文件,意味着它包含已编译(但在这种情况下不是链接)的代码。您的最终makefile规则获取目标文件并将它们链接在一起,形成一个名为reservations.out的最终可执行文件。

现在我再看一遍,看起来你的最终规则有一些奇怪的行为。我认为它看起来应该更像:

reservations.out: main.o flight.o passenger.o
    gcc -Wall -g main.o flight.o passenger.o -o reservations.out

此外,您passenger.o作为passenger.o的先决条件,这肯定会给您带来麻烦。我会做的是这样的事情(它可能更紧,但我试图让这个直截了当):

.PHONY: all clean

all: reservations.out

flight.o: flight.c flight.h
    gcc -Wall -g -c flight.c    

passenger.o: passenger.c passenger.h
    gcc -Wall -g -c passenger.c    

main.o: main.c
    gcc -Wall -g -c main.c     

reservations.out: main.o flight.o passenger.o
    gcc -Wall -g main.o flight.o passenger.o -o reservations.out

clean:
    rm -f *.o reservations.out

但是,如果你想进一步了解细节,我将真正做的事情如下。对于这么小的项目来说,这可能有点过分,但在必要时调整和调整也更容易。

.PHONY: all clean

BIN = reservations
OBJ = flight.o passenger.o main.o

all: $(BIN)

%.o: %.c %.h
    gcc -Wall -g -c $<

main.o: main.c
    gcc -Wall -g -c $<

$(BIN): $(OBJ)
    gcc -Wall -g -o $@ $^

clean:
    rm -f $(OBJ) $(BIN)

我建议您查看GNU make manual,详细了解您可以做的所有精彩内容。

答案 1 :(得分:2)

  

我不确定.o文件是什么   因为,有人请你解释一下吗?

.o是目标文件,由编译器创建的临时文件,包含类的目标代码。目标代码将由链接器链接以创建可执行的二进制文件。

答案 2 :(得分:1)

make具有从C源创建二进制文件的隐式规则,您无需为此指定显式规则。

所以你的简约Makefile看起来像

CFLAGS = -Wall -g
.PHONY all clean

all: myprogram

myprogram: source1.c source2.c

clean:
    rm -f myprogram

它有一个有用的副作用 - 编译后所有中间文件(*.o文件)将自动删除。

来自CFLAGS的选项将添加到gcc命令行 - make隐含规则执行此操作。