Makefile用于将一些.cpp和.h编译成lib

时间:2010-06-22 11:46:51

标签: c++ makefile g++ cygwin compilation

我在Cygwin下使用gcc / g ++运行Windows 7。将一组.cpp(C ++源代码)和.h(头文件)文件编译成静态库(.dll)的Makefile格式(和扩展名,我认为是.mk?)是什么?假设我有一组可变文件:

  • file1.cpp
  • file1.h

  • file2.cpp

  • file2.h

  • file3.cpp

  • file3.h

  • ....

将这些编译为静态库的makefile格式(和扩展名)是什么? (我对makefile很新)最快的方法是什么?

2 个答案:

答案 0 :(得分:2)

扩展名根本就没有,如果你想让GNU make自动找到它,那么文件名为Makefile。

Make具有自动变量,可以单独控制C / C ++文件中的大部分构建过程。这些变量包括CCCPPCFLAGSCPPFLAGSCXXCXXFLAGSLDFLAGS。这些将控制切换到C / C ++预处理器,编译器,平台对象和程序链接器(生成所谓的“程序可执行文件”的程序,或plainspeak“您正在编译的程序”)。

GNU make还包含许多隐式规则,这些规则是为了从C / C ++源代码构建程序而定制的,因此您不必从头开始编写这些规则。

例如,即使没有一个makefile,如果你尝试make foobar,GNU Make也会尝试从foobar.o或{{1}开始构建foobar.c如果它通过调用适当的编译器找到,则会尝试通过从系统库和foobar.cpp汇编(包括链接)其部分来构建foobar。简而言之,GNU Make知道如何构建foobar.o程序,即使没有makefile存在 - 多亏了隐式规则。您可以通过使用foobar开关调用Make来查看这些规则,例如-p

有些人喜欢依赖GNU Make隐式规则数据库来创建精简版和简短的makefile,其中只指定了特定于他们项目的那些,而有些人甚至可以禁用整个隐式规则数据库(使用{{1通过从头开始指定所有内容,可以完全控制构建过程。我不会对这两种策略的有效性发表评论,但请放心,两者都在某种程度上有效。

答案 1 :(得分:2)

构建dll时可以设置很多选项,但是如果您是从命令行执行此操作,则可以使用这个基本命令:

gcc -shared -o mydll.dll file1.o file2.o file3.o

这是一个makefile(通常称为Makefile),它将处理整个构建过程:

# You will have to modify this line to list the actual files you use.
# You could set it to use all the "fileN" files that you have,
# but that's dangerous for a beginner.
FILES = file1 file2 file3

OBJECTS = $(addsuffix .o,$(FILES)) # This is "file1.o file2.o..."

# This is the rule it uses to assemble file1.o, file2.o... into mydll.dll
mydll.dll: $(OBJECTS)
    gcc -shared $^ -o $@    # The whitespace at the beginning of this line is a TAB.

# This is the rule it uses to compile fileN.cpp and fileN.h into fileN.o
$(OBJECTS): %.o : %.cpp %.h
    g++ -c $< -o $@         # Again, a TAB at the beginning.

现在要构建mydll.dll,只需输入“make”。

一些笔记。如果只键入“make”而不指定makefile或目标(要构建的东西),Make将尝试使用默认的makefile(“GNUMakefile”,“makefile”或“Makefile”)和默认目标(第一个) makefile中的一个,在本例中为mydll.dll)。