stdafx的使用

简介

      头文件预编译,把project中使用的MFC标准头文件预先编译,以后在编译该project时就不再编译这部分头文件,仅仅使用预编译的结果,加快编译速度,节约时间。

原理

Stdafx.h是为定义一些参数配置,环境设置专门定义的。

APPWizard建立文件stdafx.h,该文件包含了所有当前工程需要的MFC include文件,且这一文件可以被选择的选项而变化;

AppWizard然后建立stdafx.cpp。这个文件通常是一样的;

AppWizard建立工程文件,第一个被编译的文件就是stdafx.cpp;

当Visual C++编译stdafx.cpp文件时,它将结果保存在一个名为stdafx.pch的文件里(扩展名pch表示预编译头文件);

当编译器编译随后的每个.cpp文件时,它阅读并使用它刚生成的.pch文件,Visual C++不再分析Windows include文件,除非stdafx.cpp或stdafx.h又被编辑;

遵守的规则

任何.cpp文件都必须首先包含stdafx.h;

如果有project文件里的大多数.cpp文件需要.h文件,顺便将它们加在stdafx.h(后部)上,然后预编译stdafx.cpp;

由于.pch文件具有大量的符号信息,它是project文件里最大的文件。如果磁盘空间有限,可以将从没使用过的project file中的。Pch文件删除,执行程序时并不需要它们,且随着工程文件的重新建立,它们也自动地重新建立。

存在的问题

一般将常用的不变的库头文件放在里面,通常的com里import进来的dll,lib也放在这里面。编译一次,其他地方直接用编译出的结果。但也会因为使用不当而引起错误,以下是常见错误:

1)  在其他的.h文件里也include”stdafx.h”.

问题描述:你的project里用了别人写的.h文件,导致你的编译速度奇慢无比,而且你做任何的小修改,编译都需要很长时间,预编译根本没有发挥作用,这个就可能给你h文件的人用错了预编译文件。

原因:由于你用到的.h文件里include了stdafx,在他本身的project里,VS能够判断的出他是预编译头,也能找到pch,pdb文件。所以对写这个.h文件的人没有影响。你作为他的客户,你工作在你的project下,include了他的h头文件,而这时VS判断不出他的头文件里include的stdafx是预编译头文件,当做普通文件编译。可想而知,他的stdafx里如果有import外面大型的库,编译速度会比较慢。

结论:不要在h头文件里include你的stdafx.h。

2)  Stdafx.h里include自己的头文件。

一般不会犯这个错误,原因很简单,自己的头文件总是变化,改了后导致stdafx重编,降低了编译速度。

       对于import外面的库,建议全部写到stdafx里面去,不要在h头文件里import。用你的h头文件的人,要求在他的stdafx里include你的stdafx。这样的话,实际上这个stdafx在两个工程里面是会编译2次的。但你做的修改的编译速度是很快的。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值