stdafx

stdafx是一款应用程序,应用十分简单。

stdafx.h中没有函数库,只是定义了一些环境参数,使得编译出来的程序能在32位的操作系统环境下运行。


中文名 标准应用框架扩展 

外文名 Standard Application Framework Extensions 

全    名 stdafx 

stdafx.h  标准系统包含文件的包含文件 

生成条件 编译stdafx.cpp生成


目录

1 定义

2 工作原理

3 作用

4 文件的问题


定义

所谓头文件预编译,就是把一个工程(Project)中使用的一些MFC标准头文件(如Windows.H、Afxwin.H)预先编译,以后该工程编译时,不再编译这部分头文件,仅仅使用预编译的结果。这样可以加快编译速度,节省时间。
afx曾经是微软一个专门的技术开发团队,而stdafx.h则是这个团队为了定义一些环境配置、参数设置等专门定义的。


工作原理

Windows和MFC的include文件都非常大,即使有一个快速的处理程序,编译程序也要花费相当长的时间来完成工作。由于每个.CPP文件都包含相同的include文件,为每个.CPP文件都重复处理这些文件就显得很傻了。
为避免这种浪费,AppWizard和VisualC++编译程序一起进行工作,如下所示:
◎AppWizard建立了文件stdafx.h,该文件包含了所有当前工程文件需要的MFCinclude文件。且这一文件可以随被选择的选项而变化。
◎AppWizard然后就建立stdafx.cpp。这个文件通常都是一样的。
◎然后AppWizard就建立起工程文件,这样第一个被编译的文件就是stdafx.cpp。
◎当VisualC++编译stdafx.cpp文件时,它将结果保存在一个名为stdafx.pch的文件里。(扩展名pch表示预编译头文件。)

◎当VisualC++编译随后的每个.cpp文件时,它阅读并使用它刚生成的.pch文件。VisualC++不再分析Windowsinclude文件,除非你又编辑了stdafx.cpp或stdafx.h。

stdafx.h->stdafx.cpp->编译cpp结果存在stdafx.pch里->编译.pch

在这个过程中你必须遵守以下规则:

◎你编写的任何.cpp文件都必须首先包含stdafx.h。
◎如果你有工程文件里的大多数.cpp文件需要的.h文件,顺便将它们加在stdafx.h(后部)上,然后预编译stdafx.cpp。
◎由于.pch文件具有大量的符号信息,它是你的工程文件里最大的文件。

如果你的磁盘空间有限,你就希望能将这个你从没使用过的工程文件中的.pch文件删除。执行程序时并不需要它们,且随着工程文件的重新建立,它们也自动地重新建立。


作用

stdafx.h的作用
当我们使用AppWizard来自动生成某些项目的时候,系统会自动把所需要include的头文件在stdafx.h中先include一下,这样,我们只需要直接include这个stdafx.h文件即可.因为同一个项目中的不同源文件CPP都包含相同的include文件,这样,为每个.CPP文件都重复include这些文件就显得很傻了。
具体在stdafx.h中需要include什么头文件,取决于用户在AppWizard中的选择.
比如:
#include <afxwin.h> // MFC core and standard components
#include <afxext.h> // MFC extensions
#include <afxole.h> // MFC OLE classes
#include <afxodlgs.h> // MFC OLE dialog classes
#include <afxdisp.h> // MFC Automation classes
......
看了这样的讲解,我马上就实验了一下,自己新建立一个windows窗口项目,很快,就生成了stdafx.cpp和stdafx.h.
并且,在主源文件form1.cpp中,就include此头文件stdafx.h.

以上情况,只在使用AppWizard来自动生成项目的时候,才出现.否则,就没有必要include此头文件stdafx.h了


stdafx.h : 标准系统包含文件的包含文件。

Microsoft C 和 C++编译器提供了用于预编译任何 C 或 C++代码(包括内联代码)的选项。利用此性能特性,可以编译稳定的代码体,将已编译状态的代码存储在文件中,以及在随后的编译中,将预编译的代码与仍在开发的代码结合起来。由于不需要重新编译稳定代码,因此后面每次编译的速度都要快一些。
预编译代码有助于在开发周期中缩短编译时间,特别是在以下情况中:
一:总是使用不经常改动的大型代码体。
二:程序由多个模块组成,所有模块都使用一组标准的包含文件和相同的编译选项。在这种情况下,可以将所有包含文件预编译为一个预编译头。
三: 用于创建预编译头文件的第一次编译所花费的时间比后面的编译稍长一些。通过包含预编译代码可以加快后面的编译速度。C 和 C++ 程序都可以预编译。在 C++ 编程中,常见的做法是将类接口信息分别放到不同的头文件中。此后就可以将这些头文件包含在使用该类的程序中。通过预编译这些头文件,可以缩短程序的编译时间。
VC创建项目时自动创建的预编译头文件,在编译其他文件之前,VC先预编译此文件。头文件stdafx.h引入了项目中需要的一些通用的头文件,比如window.h等,在自己的头文件中包括stdafx.h就包含了那些通用的头文件。
预编译头文件通过编译stdafx.cpp生成,以工程名命名,由于预编译的头文件的后缀是“pch”,所以编译结果文件是projectname.pch。
编译器通过一个头文件stdafx.h来使用预编译头文件。stdafx.h这个头文件名是可以在project的编译设置里指定的。编译器认为,所有在指令#include "stdafx.h"前的代码都是预编译的,它跳过#include "stdafx. h"指令,使用projectname.pch编译这条指令之后的所有代码。

因此,所有VC实现的CPP文件第一条语句都是:#include "stdafx.h"。


文件的问题

我们都知道,他是预编译头文件,就是说,我们在stdafx.cpp里include一次,生成一次pch,pdb文件,其他地方实际上直接用这个编译的结果,从而减少编译时间,提高编译效率。一般,我们把常用的不变的库头文件放里面,如,atlbase.h,atlcore.h,windows.h等,通常的com里import进来的dll,tlb也放这个里面,这样,它能做到,只编译一次,其他地方直接用编译出的结果。
以上是如果stdafx被正确使用时,它确实大大提高我们编程的效率(你工作中,有多少时间是在等编译完成?很多吧,这个时候一般都很无聊,无奈,浪费时间),但是他太容易用错了。

如果在其他的.h文件里也include "stdafx.h".则会产生问题:你的project里用了别人写的.h文件,导致你的编译速度奇慢无比,而且你做任何小的修改,编译都要好久好久,等的心烦,预编译根本没发挥作用。这个就可能给你h文件的人用错预编译文件了。由于你用到的.h文件里include了stdafx,他在他本身的project里,vs能够判断的出他是预编译头,也能找的到需要的pch,pdb文件。所以对写这个.h文件的人没影响。但是你作为他的客户,你工作在你的project下,你include了他的h头文件,而这时vs判断不出他的头文件里include的stdafx是预编译头文件,做普通文件编。那可想而知,他的stdafx里如果有import外面大型的库(如inventor的tlb,非常慢,我们犯了这个错),那编译速度简直是煎熬。最要命的是,以后你做任何简单的修改,这个stdafx都要重编,这和预编译解决的问题恰好相反了。所以,绝对不要在h头文件里(特别是发布给外面人用的h头文件)里include你的stdafx.h!


stdafx.h里面包含什么


包含VC++目录下的引用的.h文件。每个文件夹内的.h不能重名。

.h文件是用来声明函数的原型的。函数的实现最好写在cpp里。

引用类的静态函数要用::不用.


posted @ 2018-07-07 21:32  lightmare  阅读(425)  评论(0编辑  收藏  举报