VS2010工程结构及其瘦身策略
VS2010工程结构:
我们以在VS2010上利用MFC创建的单文档应用程序HelloWorld的文件结构为例,简述VS2010应用程序工程中文件的组成结构。
1、解决方案相关文件
解决方案相关文件包括解决方案文件夹下的.sdf文件、.sln文件、.suo文件和ipch文件夹。
.sdf文件和ipch目录等浏览数据库与智能提示、错误提示、代码恢复和团队本地仓库等相关,支持智能浏览感知编辑、显示类视图等,一般占用空间比较大,几十兆甚至上百兆,不方便工程项目的打包备份。如果你觉得不需要则可以设置不生成它们,方法是点击菜单栏“工具”->“选项”对话框 ->“文本编辑器”->“c/C++”->“高级”->“浏览/导航”->“禁用数据库”,将数据库禁用,最后关闭VS2010再删除.sdf文件和ipch目录以后就不会再产生了。但关闭此选项以后也会有很多不便,例如写程序时的智能提示没有了。
.sln文件和.suo文件为MFC自动生成的解决方案文件,它包含当前解决方案中的工程信息,存储解决方案的设置。
2、工程相关文件
工程相关文件包括工程文件夹下的.vcxproj文件和.vcxproj.filters文件。
.vcxproj文件是MFC生成的工程文件,它包含当前工程的设置和工程所包含的文件等信息。.vcxproj.filters文件存放工程的虚拟目录信息,也就是在解决方案浏览器中的目录结构信息。
3、应用程序头文件和源文件
应用程序向导会根据应用程序的类型(单文档、多文档或基于对话框的程序)自动生成一些头文件和源文件,这些文件是工程的主体部分,用于实现主框架、文档、视图等。
HelloWorld.h:应用程序的主头文件。主要包含由CWinAppEx类派生的CHelloWorldApp类的声明,以及CHelloWorldApp类的全局对象theApp的声明。
HelloWorld.cpp:应用程序的主源文件。主要包含CHelloWorldApp类的实现,CHelloWorldApp类的全局对象theApp的定义等。
MainFrm.h和MainFrm.cpp:通过这两个文件从CFrameWndEx类派生出CMainFrame类,用于创建主框架、菜单栏、工具栏和状态栏等。
HelloWorldDoc.h和HelloWorldDoc.cpp:这两个文件从CDocument类派生出文档类CHelloWorldDoc,包含一些用来初始化文档、串行化(保存和装入)文档和调试的成员函数。
HelloWorldView.h和HelloWorldView.cpp:它们从CView类派生出名为CHelloWorldView的视图类,用来显示和打印文档数据,包含了一些绘图和用于调试的成员函数。
ClassView.h和ClassView.cpp:由CDockablePane类派生出CClassView类,用于实现应用程序界面左侧面板上的Class View。
FileView.h和FileView.cpp:由CDockablePane类派生出CFileView类,用于实现应用程序界面左侧面板上的File View。
OutputWnd.h和OutputWnd.cpp:由CDockablePane类派生出COutputWnd类,用于实现应用程序界面下侧面板Output。
PropertiesWnd.h和PropertiesWnd.cpp:由CDockablePane类派生出CPropertiesWnd类,用于实现应用程序界面右侧面板Properties。
ViewTree.h和ViewTree.cpp:由CTreeCtrl类派生出CViewTree类,用于实现出现在ClassView和FileView等中的树视图。
4、资源文件
一般我们使用MFC生成窗口程序都会有对话框、图标、菜单等资源,应用程序向导会生成资源相关文件:res目录、HelloWorld.rc文件和Resource.h文件。
res目录:工程文件夹下的res目录中含有应用程序默认图标、工具栏使用图标等图标文件。
HelloWorld.rc:包含默认菜单定义、字符串表和加速键表,指定了默认的About对话框和应用程序默认图标文件等。
Resource.h:含有各种资源的ID定义。
5、预编译头文件
几乎所有的MFC程序的文件都要包含afxwin.h等文件,如果每次都编译一次则会大大减慢编译速度。所以把常用的MFC头文件都放到了stdafx.h文件中,然后由stdafx.cpp包含stdafx.h文件,编译器对stdafx.cpp只编译一次,并生成编译之后的预编译头HelloWorld.pch,大大提高了编译效率。
6、编译链接生成文件
若是Debug方式编译,则会在解决方案文件夹和工程文件夹下都生成Debug子文件夹,而若是Release方式编译则生成Release子文件夹。这两种编译方式将产生两种不同版本的可执行程序:Debug版本和Release版本。Debug版本的可执行文件中包含了用于调试的信息和代码,而Release版本则没有调试信息,不能进行调试,但可执行文件比较小。
工程文件夹下的Debug或Release子文件夹中包含了编译链接时产生的中间文件,解决方案文件夹下的Debug或Release子文件夹中主要包含有应用程序的可执行文件。
瘦身策略:
.sdf文件和ipch目录等浏览数据库与智能提示、错误提示、代码恢复和团队本地仓库等相关,支持智能浏览感知编辑、显示类视图等,一般占用空间比较大,几十兆甚至上百兆,不方便工程项目的打包备份,如果你觉得不需要则可以设置不生成它们。
1、点击菜单栏“工具”->“选项”对话框 ->“文本编辑器”->“C/C++”->“高级”->“浏览/导航”->“禁用数据库”,将数据库禁用,最后关闭VS2010再删除.sdf文件和ipch目录以后就不会再产生了。但关闭此选项以后也会有很多不便,例如写程序时的智能提示没有了。(不建议)
2、为.sdf文件和ipch目录设置专门的temp目录,转移sdf文件和ipch文件的位置,统一管理。方法:点击菜单栏“工具”->“选项”对话框 ->“文本编辑器”->“C/C++”->“高级”->“回退位置”,两个都设置为“true”,并设置temp目录,如下图所示:
3、写一个批处理文件来清理:新建一个.txt文件,将以下内容写入其中,并保存为后缀名为.bat的文件,将其放入到工程文件夹下,双击即可自动将sdf,ipch等占用空间很大的文件删除。这样的方式较之于转移浏览数据库文件的位置而言更为灵活一些,不用特别的设置VS的选项。(这种方式是彻底删除,不会在回收站找到)
echo 正在清理VS2010工程中不需要的文件 echo 请确保本文件放置在工程目录之中并关闭VS2010 echo 开始清理请稍等...... echo 清理sdf文件 del /q/a/f/s *.sdf echo 清理ipch文件 del /q/a/f/s ipch\*.* echo 清理Debug文件 del /q/a/f/s Debug\*.obj del /q/a/f/s Debug\*.tlog del /q/a/f/s Debug\*.log del /q/a/f/s Debug\*.idb del /q/a/f/s Debug\*.pdb del /q/a/f/s Debug\*.ilk del /q/a/f/s Debug\*.pch del /q/a/f/s Debug\*.bsc del /q/a/f/s Debug\*.sbr echo 清理Release文件 del /q/a/f/s Release\*.obj del /q/a/f/s Release\*.tlog del /q/a/f/s Release\*.log del /q/a/f/s Release\*.idb del /q/a/f/s Release\*.pdb del /q/a/f/s Release\*.ilk del /q/a/f/s Release\*.pch echo 清理Temp文件 del /q/a/f/s Temp\*.* ECHO 文件清理完毕!本程序将在3秒后退出!现在进入倒计时......... @echo off echo WScript.Sleep 300 > %temp%.\tmp$$$.vbs set /a i =3 :Timeout if %i% == 0 goto Next setlocal set /a i = %i% - 1 echo 倒计时……%i% cscript //nologo %temp%.\tmp$$$.vbs goto Timeout goto End :Next cls & echo.
参考网址:
高洪臣 (Gavin Gao)
cggos@outlook.com
=======================================================================