make如何推断最终目标需要什么样的编译器
how can the make infer what kind of compiler it needs for the final target?
这里有一个简单的makefile。这是一个最低限度的c++项目,我希望make使用隐式规则进行正确的行为。使用以下makefile,它将报告错误。然后我键入"make-n",看起来make使用的是cc而不是cxx。但当我查看GNU页面时,它说CXX是一个隐式变量:https://www.gnu.org/software/make/manual/html_node/Implicit-Variables.html
我可以说最后的目标是什么。隐含的工具总是cc?
objects = test.o main.o
CXX=g++
CFLAGS=-std=c++11
test: $(objects)
.PHONY: clean
clean:
rm -f *.o test
您的对象文件很可能是使用Make的默认链接器$(CC)
链接的。我们可以看到,如果我们看看make --print-data-base -f /dev/null
的输出,特别是:
%: %.o # recipe to execute (built-in): $(LINK.o) $^ $(LOADLIBES) $(LDLIBS) -o $@
如果我们看看LINK.o
的定义,我们会看到:
# default LINK.o = $(CC) $(LDFLAGS) $(TARGET_ARCH)
幸运的是,Make提供LINK.cc
正是为了我们的目的:
# default LINK.cc = $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH)
所以我们所需要做的就是将LINK.o
重新定义为LINK.cc
的值,并且链接将由我们的C++编译器完成:
LINK.o = $(LINK.cc)
如果我们有几个目标,以不同的方式联系起来,我们可能会使用一个目标相关变量来定位效果:
test: LINK.o = $(LINK.cc)
makefile上的其他注释:
test
对程序来说是个糟糕的名字——很容易错误地运行标准的/usr/bin/test
- 你可能是指
CXXFLAGS=-std=c++11
(而不是CFLAGS
) - 所有makefile都应该包含一个
.DELETE_ON_ERROR:
目标,这样被中断的命令就不会留下最新的部分输出
相关文章:
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么所有C++编译器都会崩溃或挂起此代码
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- make如何推断最终目标需要什么样的编译器
- 什么样的编译器开关使逆向工程师的生活更加艰难/轻松