2014年4月12日星期六

关于 visual studio 2010 intellisense cannot open source file "stdafx.h" 的解决方法

    下午将近要离开实验室的时候,我尝试着使用 namespace 来把我自己的代码纳入统一的命名空间,以免和其它同名的全局函数产生冲突,另外还新建了一个 calib3d 的 .cpp,新建完之后发现自己新建立的 .h 和 .cpp 都在工程目录下,包括之前新建的 typedef 的 .cpp,于是想当然的在系统目录下新建了个新的专属自己代码库的文件夹,并把所有自己的 .cpp 和 .h 都挪了进去,这一挪可就出问题了,自己代码所有的 .cpp 文件中 #include "stdafx.h" 都被 IDE 的 IntelliSense 提示说 cannot open source file "stdafx.h",.cpp 里要是真不能 include stdafx.h 也就意味着基本上工程中定义的所有的 struct class 等都不能识别了,都是 undefined 的,但是令人困惑的是 compile 能顺利通过,仅仅是 IntelliSense 的各种提示功能不能正常工作,不能识别各种结构,本来想这样的话,干脆别深究,就将就着算去,但是后来看看那一道道提示 error 的红线感觉实在闹心,就决心一定要查个明白,google 了老半天才终于在下面这个 msdn 的 blog 中找到了答案:
http://blogs.msdn.com/b/vcblog/archive/2010/02/19/improving-c-intellisense-performance-with-pch.aspx?PageIndex=2
其中 Windows C++ Team 的 Ulzii Luvsanbat 这样解释道:
The reason why build compiler succeeded when intellisense failed on #include "stdafx.h" is because you were still using PCH for the project and the new file inherited that property.  So, when build compiler sees #include "stdafx.h" it automatically loads the .pch file without doing any look-up for the actual header file.  Once PCH is loaded, all symbols resolve and build succeeds.  If you turn-off PCH for the project and do a Re-Build, you will see a compiler error in the output that's same as the Intellisense squiggle error.
When you add #include "stdafx.h" to any file the compiler or intellisense parser will follow the lookup heuristic of searching current directory and then searching INCLUDE path.  In both cases stdafx.h will not found because it's in the $(ProjectDir) folder and your source is in a different folder. One easy way fix this in your project would be to add $(ProjectDir) to your Include Directories under "VC++ Directories" property.
    他的意思简单点说就是,当 .cpp 文件不在工程目录中时,IntelliSense Parser 就会在 .cpp 当前的文件夹中去找 .cpp 中所包含的 stdafx.h,结果发现找不到,然后接着又在 INCLUDE path 里面去找,发现也找不到,因为 stdafx.h 是在工程目录下的,当 .cpp 和  stdafx.h 同在工程目录中时,这就没有问题,但一旦不在一个目录 IntelliSense Parser 就会找不到 stdafx.h 了,所以当我把之前在工程目录中的 typedef.cpp 挪过来的时候会出现这样的问题,而之前都没有,解决方法就是在 "VC++ Directories" 的 Include Directories 中添加 $(ProjectDir),这个路径应该就是工程自己的路径了。经过自己一试发现问题果然没了,problem solved。
这其实是我在Blogbus上于14年3月3号发布的一篇博文,现在转移到这里来

没有评论:

发表评论