我在Cygwin下使用gcc / g ++运行Windows 7。将一组.cpp(C ++源代码)和.h(头文件)文件编译成静态库(.dll)的Makefile格式(和扩展名,我认为是.mk?)是什么?假设我有一组可变文件:
file1.h
file2.cpp
file2.h
file3.cpp
file3.h
....
将这些编译为静态库的makefile格式(和扩展名)是什么? (我对makefile很新)最快的方法是什么?
答案 0 :(得分:2)
扩展名根本就没有,如果你想让GNU make自动找到它,那么文件名为Makefile。
Make具有自动变量,可以单独控制C / C ++文件中的大部分构建过程。这些变量包括CC
,CPP
,CFLAGS
,CPPFLAGS
,CXX
,CXXFLAGS
和LDFLAGS
。这些将控制切换到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
)。