Why stdfax.h should be the first include on MFC applications?(为什么 stdfax.h 应该是 MFC 应用程序的第一个包含?)
问题描述
我想知道为什么每个 MFC 应用程序都存在这条线(这迫使 stdafx.h 成为每个文件中包含的第一个标头):
I want to know why this line exists on every MFC app (which force to make stdafx.h the first header included in every file) :
#ifndef __AFXWIN_H__
#error "include 'stdafx.h' before including this file for PCH"
#endif
这种行为背后的原因是什么?
What are the reason(s) behind this behavior ?
推荐答案
只有在使用Precompiled Headers (PCH)时才会这样,以及为什么在#include "stdafx.h"之前不应该有任何东西的原因 是:
It's only true when using Precompiled Headers (PCH), and the reason why there shouldn't be anything before the #include "stdafx.h" is :
Visual C++ 不会在 #include "stdafx.h" 之前编译任何内容源文件,除非编译选项/Yu'stdafx.h' 未选中(默认情况下);它假定源代码中的所有代码,包括该行已经编译
Visual C++ will not compile anything before the #include "stdafx.h" in the source file, unless the compile option /Yu'stdafx.h' is unchecked (by default); it assumes all code in the source up to and including that line is already compiled
来自 http://en.wikipedia.org/wiki/Precompiled_header
这篇关于为什么 stdfax.h 应该是 MFC 应用程序的第一个包含?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么 stdfax.h 应该是 MFC 应用程序的第一个包含?
基础教程推荐
- 将不可复制的闭包对象传递给 std::function 参数 2021-01-01
- 如何更改 SysDateTimePick32 或 CDateTimeCtrl 的背景颜色? 2022-01-01
- 随机插入/删除的综合向量与链表基准 2022-01-01
- 提升 ASIO 流缓冲 2021-01-01
- 为什么我们不能使用“虚拟继承"?在 COM 中? 2022-01-01
- C++:获取传递给函数的多维数组的行大小 2021-01-01
- 与 CAS 的原子交换(使用 gcc 同步内置函数) 2022-01-01
- 如何在 C++ 中正确使用命名空间? 2022-01-01
- 如何部分禁用 cmake C/C++ 自定义编译器检查 2021-01-01
- c++ STL设置差异 2022-01-01
