企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
接着上一篇文章[带你玩转Visual Studio——开篇介绍](http://blog.csdn.net/luoweifu/article/details/48664887)继续讲这个主题,现在我们从创建一个新的工程开始。 # 一步一步创建项目 1. 依次选择菜单:File\New\Project,打开New Project对话框。 2. .选择项目类型:Win32 Console Application;.填写工程名(Project Name):TestProject(可以给它取一个任意你想要的名字);.选择该工程存放的路径:D:\CppWorkspace。  ![](https://box.kancloud.cn/2016-01-19_569dd0373cdf8.jpg)  图 1:New Project 你可能会想问:列表里这么多工程类型,分别代表什么含义啊? 这个问题后面再讨论,你先记住这张图。 1. 点击Ok,然后点击Next,会出现这一步  ![](https://box.kancloud.cn/2016-01-19_569dd0375d08b.jpg)  图 2:Application Settings 2. 我们就采用默认的设置,点击Finish,工程创建完成。  (这是工程相关的设置,同样先不用管它,先记住这张图,后面再讨论)。 * * * # 工程结构与目录结构 ## 工程结构 ![](https://box.kancloud.cn/2016-01-19_569dd03770c57.jpg)  图 3:工程结构 创建完成之后,我们会在左侧看到这样一个工程结构。分别说明如下:  **External Dependencies:**  工程的外部依赖文件,这个目录是VS自动生成的,你最好别动它。 **Header Files:**  头文件,也就是.h(.hpp)后缀的头文件。 **Source Files:**  源文件,也就.cpp(或.c,针对C语言)后缀的文件。 **Header Files:**  资源文件,如果你创建的是MFC的工程,*.rc文件就会在这里。 ### 工程结构的作用: 1. 方便管理,将不同类型或不同用途的文件配制在不同的结构下,方便文件的浏览、查找和代码的管理。 2. 工程结构的目录与真实文件的目录不一定相同。 3. 你可以根据文件的不同用途或不同含义,对工程结构重新配置。  比如我觉得Source Files和Header Files这名太长,你可以选中它按F2,分别把它改重命名成Source和Header。关于工程结构的自定义配置,后续章节的文章还会再提到。 ## 目录结构 ![](https://box.kancloud.cn/2016-01-19_569dd03784400.jpg)  图 4:目录结构 正如上面提到的“工程结构的目录与真实文件的目录不一定相同”,我们在文件管理器中打开TestProject所在的目录,可以看到 *.h 和 *.cpp文件都在同一个目录下,在我的目录里也就是位于D:\CppWorkspace\TestProject\TestProject。 * * * # 写一个HelloWorld程序 所有计算机语言的学习都从HelloWorld开始,Ok,那我们也从HelloWorld开始写一个程序吧!在TestProject.cpp文件中写一个HelloWorld程序如下: ~~~ #include "stdafx.h" #include <iostream> using namespace std; int _tmain(int argc, _TCHAR* argv[]) { cout << "Hello World" << endl; return 0; } ~~~ 编译:  右键工程名TestProject选择Build,或者点击菜单Build\Build Project。 运行:  内容太简单,直接运行吧,按Ctrl+F5或点击菜单Debug\Start Without Debugging。  ![](https://box.kancloud.cn/2016-01-19_569dd037a1081.jpg)  图 5:程序运行结果 * * * # 工程目录下各文件的含义 一般大部分的文章可能介绍到上面就算结束了,但我这还没有。创建工程产生的各个文件都你知道是什么用的吗? 如果你是一个初学者,你可能会不知道(老手请跳过本文)。Ok,我就带你逐一了解吧。 ## 解决方案与工程 在这之前先了解一个概念:解决方案与工程。  **解决方案(Solution):**一个大型项目的整体的工作环境;  **工程 (Project):**一个解决方案下的一个子工程; 在VS中,**一个Solution可以有一个或多个Project**。在我们创建一个工程时,如果没有指定Solution,VS会帮我们创建一个与工程名相同的Solution,这时一个Solution里只有一个Project。所有在我们的TestProject的文件目录结构中TestProject文件夹下还有一个TestProject文件夹(如图4),第一个就是整个Solution的目录,第二个才是Project的目录。 ## 解决方案相关的文件: **TestProject.sln:**  整个解决方案(Solution)的配制文件,组织多个工程和相关的元素到一个解决方案中。用鼠标双击它就能用VS打开整个工程项目。 **TestProject.sdf:**  浏览相关的数据库文件,它支持浏览和导航的特性。如跳转到方法、变量的声明,查找所有对象的所有被引用的地方,类视图等等。 **TestProject.suo:**  (solution user opertion) 解决方案用户选项,记录所有将与解决方案建立关联的选项, 以便在每次打开时,它都包含您所做的自定义设置. **TestProject.opensdf:**  打开解决方案(Solution)时的临时文件,这个文件只有你的解决方案在VS打开的状态才会有,工程一关闭文件就被删除了。 ## 工程相关的文件 **TestProject.vcxproj:**  记录工程(Project)相关的属性配制。 **TestProject.vcxproj.filters:**  文件过虑器,上图3“工程结构”中各个文件的组织和编排都是定义在这个文件中的。如果由于某种特殊的原因(如系统或VS突然崩溃)导致你打开工程时文件的组织结构是乱的,100%就是这个文件的原因。 **TestProject.vcxproj.user:**  用户相关的一些配制。 上面这些文件中有几个比较重要的一定不能删的文件是:  TestProject.sln、TestProject.vcxproj、TestProject.vcxproj.filters 不要问我是怎样知道这些文件的作用的,请看官方文档:  VS2010定义:[https://msdn.microsoft.com/en-us/library/3awe4781.aspx](https://msdn.microsoft.com/en-us/library/3awe4781.aspx).  VS2015定义:[https://msdn.microsoft.com/en-us/library/vstudio/hx0cxhaw(v=vs.110).aspx](https://msdn.microsoft.com/en-us/library/vstudio/hx0cxhaw%28v=vs.110%29.aspx) 当然有一些说明是需要经过项目的实践才能理解的。 * * * * * * 上一篇回顾:  [带你玩转Visual Studio——开篇介绍](http://blog.csdn.net/luoweifu/article/details/48664887) 下一篇要讲述的内容:  **带你玩转Visual Studio——带你了解VC++各种类型的工程**