blob: 0808fbfc4a63fe3dca445c3d005769cd618252c7 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>NetBeans IDE C/C++ 项目快速入门教程</title>
<meta name="KEYWORDS" content="NETBEANS, TUTORIAL, C/C++, PROJECTS">
<meta name="DESCRIPTION" content="Short tutorial that demonstrates working with C/C++
projects in NetBeans IDE">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" >
<link rel="stylesheet" type="text/css" href="../../../netbeans.css">
</head>
<body>
<a name="top"></a>
<h1>C/C++ 项目快速入门教程</h1>
<!-- START INTRO ---------------------------------------------------------------------------------------* -->
<div class="articledate" style="margin-left: 0px;font-style:italic;">
<p>撰稿人:<i>Ann Rice</i>,维护人:<i>Susan Morgan</i> <br> <em>2014 年 3 月</em> [修订版本号:V8.0-1]</div>
<p>本简明教程将介绍在 NetBeans IDE 中创建和配置 C 或 C++ 项目的基本步骤。
</p>
<!-- END INTRO -->
<p><b>目录</b></p>
<img alt="此页上的内容适用于 NetBeans IDE 7.2 及更高版本" class="stamp" src="../../../images_www/articles/73/netbeans-stamp-80-74-73.png" title="此页上的内容适用于 NetBeans IDE 7.2 及更高版本">
<ul class="toc">
<li><a href="#requirements" title="要求">要求</a></li>
<li><a href="#projects" title="创建 C 和 C++ 项目">创建 C 和 C++ 项目</a></li>
<li><a href="#running" title="运行项目">运行项目</a></li>
<li><a href="#existingsourcesprojects" title="创建基于现有代码的 C/C++ 项目">创建基于现有源代码的 C/C++ 项目</a></li>
<li><a href="#frombinaryprojects" title="创建基于二进制文件的 C/C++ 项目">创建基于二进制文件的 C/C++ 项目</a></li>
<li><a href="#nextsteps" title="后续步骤">后续步骤</a></li>
</ul>
<h2><a NAME="requirements"></a>要求</h2>
<p><b>要学习本教程,您需要具备以下软件和资源。</b> </p>
<table>
<tbody>
<tr>
<th class="tblheader" scope="col">软件或资源</th>
<th class="tblheader" scope="col">要求的版本</th>
</tr>
<tr>
<td class="tbltd1">NetBeans IDE</td>
<td class="tbltd1"><a href="https://netbeans.org/downloads/index.html">带有 NetBeans C/C++ 插件的版本 7.2 或更新版本</a></td>
</tr>
<tr>
<td class="tbltd1">Java 开发者工具包 (JDK)</td>
<td class="tbltd1"><a href="http://www.oracle.com/technetwork/java/javase/downloads/index.html">版本 6、7 或 8</a> </td>
</tr>
<tr>
<td class="tbltd1">
C 和 C++ 编译器、<tt>make</tt><tt>gdb</tt>
</td>
<td class="tbltd1">
<a href="../../../community/releases/80/cpp-setup-instructions.html">配置 NetBeans IDE 以使用 C/C++/Fortran</a>
</tr>
</tbody>
</table>
<br>
<p>有关下载并安装所需软件的信息,请参见 <a href="../../../community/releases/80/install.html">NetBeans IDE 安装说明</a><a HREF="../../../community/releases/80/cpp-setup-instructions.html">配置 NetBeans IDE 以使用 C/C++/Fortran</a><br></p>
<p><b>样例项目</b>
</p>
<p>如果只需使用 IDE 中提供的某些样例项目,请选择 "File"(文件)>&nbsp;"New Project"(新建项目),然后打开 "Sample"(样例)类别和 "C/C++" 子类别。IDE 提供了一些 C 和 C++ 样例项目来帮助您熟悉 IDE。
</p>
<h2><a name="projects"></a>创建 C 和 C++ 项目</h2>
<p>NetBeans C/C++ 支持允许您通过生成的 makefile 创建 C 和 C++ 应用程序及库项目,并且还允许创建基于现有源代码的 C 和 C++ 项目。
</p>
<p>可以在本地主机(从中启动 IDE 的系统)或运行 UNIX® 操作系统的远程主机上构建、运行和调试项目。有关为项目指定工具集合以及定义和使用远程主机的信息,请参见<a href="development-environment.html">定义 C/C++ 项目的开发环境</a>
</p>
<p>
对于 C/C++ 应用程序、动态库或静态库项目,IDE 控制应用程序如何构建、运行和调试的各个方面。您可在创建项目时,或在 "Project Properties"(项目属性)对话框中指定项目设置。IDE 生成一个 makefile 来存储所有设置。
</p>
<div class="indent">
<h3><a name="CreatingApp"></a>创建 C/C++ 应用程序项目</h3>
<ol>
<li>选择“文件”>“新建项目”以打开新建项目向导。</li>
<li>在向导中,选择 "C/C++" 类别。</li>
<li>
该向导提供了多种类型的新项目供您选择。选择 "C/C++ Application"(C/C++ 应用程序),然后单击 "Next"(下一步)。 <br> <img alt="新建项目向导的屏幕快照" class="margin-around" src="../../../images_www/articles/72/cnd/quickstart/creating_application.png">
</li>
<li>
通过向导并使用默认设置来创建一个 "C/C++ Application"(C/C++ 应用程序)项目。您可以选择项目的名称和位置。
</li>
<li>单击 "Finish"(完成)退出向导。</li>
</ol>
<p>
现已创建了一个具有逻辑文件夹的项目。逻辑文件夹不是目录。它是一种组织文件的方式,并不反映文件在磁盘上的物理存储位置。添加到逻辑文件夹的文件将自动成为项目的一部分,并且在构建项目时进行编译。
</p>
<p>
添加到 "Important Files"(重要文件)文件夹中的文件不是项目的一部分,在构建项目时不会编译。这些文件只是用于参考,并在您用现有 makefile 创建项目时提供方便。
</p>
<h3><a name="SwitchingViews"></a>在项目的逻辑视图与物理视图之间切换</h3>
<p>一个项目同时具有逻辑和物理视图。您可以在项目的逻辑视图与物理视图之间进行切换。
</p>
<ol>
<li>
选择 "Files"(文件)标签。该窗口显示项目的物理视图。它按原样体现磁盘上存储的文件和文件夹。 <br> <img alt="&quot;Files&quot;(文件)标签的屏幕快照" class="b-all margin-around" src="../../../images_www/articles/72/cnd/quickstart/files_tab.png">
</li>
<li>
选择 "Projects"(项目)标签。该窗口显示项目的逻辑视图。 <br> <img alt="&quot;Projects&quot;(项目)标签屏幕快照" class="b-all margin-around" src="../../../images_www/articles/72/cnd/quickstart/projects_tab.png">
<p class="tips">对项目运行的多数命令包含在 "Projects"(项目)标签中,而不是包含在 "Files"(文件)标签中。</p>
</li>
</ol>
<h3><a name="AddingFilesandFolders"></a>在项目中添加文件和文件夹</h3>
<p>您可以在项目中添加逻辑文件夹。
</p>
<ol>
<li>
右键单击应用程序项目的项目节点,选择 "New Logical Folder"(新建逻辑文件夹)。一个新的逻辑文件夹将添加到项目中。
</li>
<li>
右键单击新逻辑文件夹并选择 "Rename"(重命名)。输入您想要的新文件夹的名称。
</li>
</ol>
<p>您可以在现有文件夹中添加文件和文件夹。逻辑文件夹可以嵌套。
</p>
<h3><a name="AddingNewFiles"></a>在项目中添加新文件</h3>
<p>您可以在项目中添加新文件。
</p>
<ol>
<li>右键单击 "Source Files"(源文件)文件夹,然后选择 "New"(新建)> "C++ Source File"(C++ 源文件)。</li>
<li>在新建文件对话框的 "Name and Location"(名称和位置)页的 "File Name"(文件名)字段中,键入 <tt>newfile</tt><br><br> <img alt="&quot;New File&quot;(新建文件)对话框的屏幕快照" src="../../../images_www/articles/72/cnd/quickstart/adding_files.png"> <br><br>
</li>
<li>单击 "Finish"(完成)。</li>
</ol>
<p>
<tt>newfile.cpp</tt> 文件随即在向导中指定的磁盘目录下创建,并添加到 "Source Files"(源文件)文件夹中。您可以在此文件夹中添加任何类型的文件,而不仅仅是源文件。
</p>
<h3><a name="MoreNewFiles"></a>在项目中添加新文件</h3>
<ol>
<li>右键单击 "Header Files"(头文件)文件夹,然后选择 "New"(新建)> "C++ Header File"(C++ 头文件)。
</li>
<li>在新建文件对话框的 "Name and Location"(名称和位置)页的 "File Name"(文件名)字段中,键入 <tt>newfile</tt></li>
<li>单击 "Finish"(完成)。</li>
</ol>
<p>
<tt>newfile.h</tt> 文件随即在向导中指定的磁盘目录下创建,并添加到 Header Files 文件夹中。
</p>
<h3><a name="AddingExistingFiles"></a>在项目中添加现有文件</h3>
<p>
您可以使用两种方法在项目中添加现有文件:
</p>
<ul>
<li>
右键单击 "Source Files"(源文件)文件夹,然后选择 "Add Existing Item"(添加现有项)。您可以通过 "Select Item"(选择项)对话框定位到磁盘上的现有文件,并将其添加到项目中。
</li>
<li>右键单击 "Source Files"(源文件)文件夹,然后选择 "Add Existing Items from Folders"(从文件夹中添加现有项)。使用 "Add Files"(添加文件)对话框添加包含现有文件的文件夹。
</ul>
<p class="tips">
请不要使用 "New"(新建)菜单项添加现有项。"Name and Location"(名称和位置)面板会提示您该文件已存在。
</p>
<h3><a name="ProjectProperties"></a>设置项目属性</h3>
<p>
<p>创建项目时,每个项目都具有两项配置:"Debug"(调试)和 "Release"(发行)。配置是用于项目的设置集合,在您选择某个配置时,可以轻松地一次切换许多设置。用 "Debug"(调试)配置可以构建含调试信息的应用程序版本。使用 "Release"(发行)配置可以构建优化的版本。
</p>
<p>"Project Properties"(项目属性)对话框包含了项目的构建和配置信息。要打开 "Project Properties"(项目属性)对话框:
</p>
<ul>
<li>
右键单击 <tt>CppApplication_1</tt> 项目的节点,然后选择 "Properties"(属性)。 <br> <img alt="&quot;Project Properties&quot;(项目属性)对话框的屏幕快照" class="margin-around" src="../../../images_www/articles/72/cnd/quickstart/project_properties.png">
</li>
</ul>
<p>
在 "Project Properties"(项目属性)对话框中,您可以修改编译器的设置和其他配置设置,方法是选择左侧面板中的某个节点,然后在右侧面板中修改相应的属性。请选择一些节点和属性值,并观察可以设置的属性。在设置 "General"(常规)属性时,将在项目的所有配置中对这些属性进行设置。设置 "Build"(构建)、"Run"(运行)或 "Debug"(调试)属性时,将在当前选定的配置中设置属性。
<h3><a name="Configurations"></a>管理配置</h3>
<p>在 "Project Properties"(项目属性)窗口中更改的属性将存储在当前配置的 makefile 中。您可以编辑默认配置,或者创建新的配置。要创建一个新的配置:
</p>
<ol>
<li>
在 "Project Properties"(项目属性)对话框中,单击 "Manage Configurations"(管理配置)按钮。
</li>
<li>
在 "Configurations"(配置)对话框中,选择一个最符合需求的配置。对于本例,请选择 "Release" 配置并单击 "Duplicate"(复制)按钮。然后单击 "Rename"(重命名)。
</li>
<li>
在 "Rename"(重命名)对话框中,将此配置重命名为 "PerformanceRelease"。单击 "OK"(确定)。
</li>
<li>在 "Configurations"(配置)对话框中,单击 "OK"(确定)。</li>
<li>
在左面板中,选择 "C Compiler"(C 编译器)节点。
</li>
<li>
请注意,在 "Project Properties"(项目属性)对话框的 "Configuration"(配置)下拉列表中,"PerformanceRelease" 配置已选中。
</li>
<li>
在右侧面板的属性表单中,将 "Development Mode"(开发模式)由 "Release"(发行)更改为 "PerformanceRelease"。单击 "OK"(确定)。
</li>
</ol>
<p>
因为您已经创建了一个新的配置,它将使用一组不同的选项来编译应用程序。
</p>
<h3><a name="FileProperties"></a>设置源文件属性</h3>
<p>
<p>为 C 或 C++ 项目设置了项目属性后,相关属性将应用于项目中的所有文件。您也可以针对单个文件设置一些属性。
</p>
<ol>
<li>
在 "Projects"(项目)标签中右键单击 <tt>newfile.cpp</tt> 源文件,然后选择 "Properties"(属性)。
</li>
<li>单击 "General"(常规)类别,查看是否可以指定其他编译器或工具来构建此文件。您也可以使用相应的复选框从当前选定项目配置的构建中排除此文件。
<li>单击 "C++ Compiler"(C++ 编译器)类别,看看是否可以覆盖项目编译器设置以及此文件的其他属性。</li>
<li>在 "File Properties"(文件属性)对话框中单击 "Cancel"(取消)。</li>
</ol>
<h3><a name="BuildingProject"></a>构建和重新构建项目</h3>
<p>要构建项目,请执行以下操作:
<ol>
<li>
右键单击项目节点,然后选择 "Build"(构建),随即便会构建项目。构建的输出显示在 "Output"(输出)窗口中。
</li>
<li>
在主工具栏的配置下拉列表中,将配置由 "Debug" 切换为 "PerformanceRelease"。现在将使用 "PerformanceRelease" 配置构建项目。
</li>
<li>
右键单击项目节点,然后选择 "Build"(构建),随即便会构建项目。构建的输出显示在 "Output"(输出)窗口中。
</li>
</ol>
<p>要重新构建项目,请执行以下操作:</p>
<ul><li>右键单击项目节点,然后选择 "Clean and Build"(清理并构建),以便在删除之前的构建产品之后执行完整的重新构建。</li>
<li>右键单击项目节点,然后选择 "Build"(构建),以便执行增量构建。如果尚未更改之前的构建产品的源文件,则会保留这些产品。</li></ul>
<p>
通过选择 "Run"(运行)菜单中的操作或使用工具栏按钮,您可以构建、清理或清理并构建项目。项目会根据不同的配置分别保留目标文件和可执行文件,所以不必担心文件在多个配置中发生混淆。
</p>
<h3><a name="CompilingFile"></a> 编译单个文件</h3>
<p>
要编译单个源文件:
</p>
<ul>
<li>
右键单击 <tt>main.cpp</tt> 文件,然后选择 "Compile File"(编译文件)。仅该文件被编译。
</li>
</ul>
<p class="notes">
对于 "C/C++ Project With Existing Sources"(基于现有源代码的 C/C++ 项目)类型,不支持编译单个文件。
</p>
</div>
<h2><a name="running"></a>运行项目</h2>
<p>
要了解如何运行项目,您将用到 IDE 的<tt>参数</tt>样例项目。<tt>参数</tt>程序输出命令行参数。在运行该程序之前,您将在当前配置中设置一些参数。然后,您将运行该程序。
</p>
<p>
创建<tt>参数</tt>项目,设置参数并运行项目:
</p>
<ol>
<li>选择 "File"(文件)> "New Project"(新建项目)。</li>
<li>在项目向导中,展开 "Samples"(样例)类别。</li>
<li>选择 "C/C++" 子类别,然后选择 <tt>Arguments</tt>(参数)项目。单击 "Next"(下一步),然后单击 "Finish"(完成)。
</li>
<li>右键单击 <tt>Arguments_1</tt> 项目节点,然后选择 "Build"(构建)。将构建项目。</li>
<li>右键单击 <tt>Arguments_1</tt> 项目节点,然后选择 "Properties"(属性)。</li>
<li>在 "Project Properties"(项目属性)对话框中,选择 "Run"(运行)节点。</li>
<li>
在 "Run Command"(运行命令)文本字段中,键入 1111 2222 3333。单击 "OK"(确定)。 <br> <img alt="&quot;Project Properties&quot;(项目属性)对话框的屏幕快照" class="margin-around" src="../../../images_www/articles/72/cnd/quickstart/setting_arguments.png">
</li>
<li>右键单击项目节点,然后选择 "Run"(运行)。此时将运行应用程序。参数将显示在 "Output"(输出)窗口中。</li>
</ol>
<h2><a name="existingsourcesprojects"></a>创建基于现有源代码的 C/C++ 项目</h2>
<p>在创建基于现有源代码的 C/C++ 项目时,IDE 将依赖现有的 makefile 来提供如何编译和运行应用程序的指令。 </p>
<p>在本练习中,您将下载并安装开源 Loki C++ 库的源文件。Loki 要求构建 Pthreads 库,默认情况下,该库可用于 Linux、Solaris 和 Mac OS X。如果您使用的是 Windows,必须先下载 Pthreads 库,然后才能使用 Loki 源文件创建项目。</p>
<div class="indent">
<h3><a name="CreateExistingSourcesProject"></a>创建基于现有源代码的项目</h3>
<ol>
<li>如果在 Windows 上运行 IDE,请从 <a href="http://sourceware.org/pthreads-win32" target="_blank"><tt>http://sourceware.org/pthreads-win32</tt></a> 安装 Pthreads 库。
<p>为方便起见,可以<a href="ftp://sourceware.org/pub/pthreads-win32/pthreads-2005-03-08.exe">直接从此链接</a>下载 pthreads-2005-03-08.exe 安装程序。</p>
<p>
将 Pthreads 库解压缩到您的 Windows 用户目录中。</p>
</li>
<li><a href="http://sourceforge.net/projects/loki-lib" target="_blank"><tt>http://sourceforge.net/projects/loki-lib</tt></a> 下载 <tt>loki-0.1.7</tt> 库。
</li>
<li><tt>loki-0.1.7</tt> 解压缩到您所选的目录中。
</li>
<li>选择“文件”>“新建项目”以打开新建项目向导。
</li>
<li>选择 "C/C++" 类别。</li>
<li>选择 "C/C++ Project With Existing Sources"(基于现有源代码的 C/C++ 项目),然后单击 "Next"(下一步)。</li>
<li>在 "Select Mode"(选择模式)页上,单击 "Browse"(浏览)按钮。在 "Select Project Folder"(选择项目文件夹)对话框中,导航至保存 <tt>loki-0.1.7</tt> 的目录。选择 <tt>loki-0.1.7</tt> 目录。单击 "Select"(选择)按钮。 <br><br> <img alt="项目向导的 &quot;Select Mode&quot;(选择模式)页的屏幕快照" class="margin-around b-all" src="../../../images_www/articles/72/cnd/quickstart/existing_sources_project1.png"> <br><br>
</li>
<li>使用默认的配置模式("Automatic"(自动))。单击 "Finish"(完成)。
<p>
此时会在 "Projects"(项目)标签中创建并打开该项目,并且 IDE 会自动运行现有 Makefile 中指定的 "Clean and Build"(清理并构建)操作。此外,还将自动配置该项目以获取代码帮助。</p>
<img alt="使用现有源成功创建项目的屏幕快照" class="margin-around" src="../../../images_www/articles/72/cnd/quickstart/existing_sources_project2.png">
</li>
</ol>
<h3><a name="frombinaryprojects"></a>创建基于二进制文件的 C/C++ 项目</h3>
<p>您可以创建基于现有二进制文件的 C/C++ 项目。</p>
<ol>
<li>选择 "File"(文件)> "New Project"(新建项目)。</li>
<li>选择 "C/C++" 类别。</li>
<li>选择 "C/C++ Project from Binary File"(基于二进制文件的 C/C++ 项目),然后单击 "Next"(下一步)。
</li>
<li><p>在新建项目向导的 "Select Binary File"(选择二进制文件)页上,单击 "Browse"(浏览)按钮。在 "Select Binary File"(选择二进制文件)对话框中,导航至要创建项目基于的二进制文件。 </p>
<p>将会自动填充所构建二进制文件基于的源文件的根目录。默认情况下,项目中仅包含所构建二进制文件基于的源文件。默认情况下,项目中包含依赖关系。将自动列出项目所需的共享库。</p>
<img alt="新建项目向导中 &quot;Select Binary File&quot;(选择二进制文件)页的屏幕快照" class="margin-around" src="../../../images_www/articles/72/cnd/quickstart/binary_project.png">
</li>
<li>单击 "Next"(下一步)。</li>
<li>在 "Project Name and Location"(项目名称和位置)页上,可以选择项目的名称和位置。单击 "Finish"(完成)。</li>
</ol>
<h3><a name="BuildingRebuilding"></a>构建和重新构建项目</h3>
<p>要构建项目,请执行以下操作:
<ul>
<li>右键单击项目的项目节点,然后选择 "Build"(构建)。</li>
</ul>
<p>要重新构建项目:
<ul>
<li>右键单击项目的项目节点,然后选择 "Clean and Build"(清理并构建)。</li>
</ul>
</div>
<h2><a name="nextsteps">后续步骤</a></h2>
<p>请参见<a href="navigating-editing.html">编辑和导航 C/C++ 源文件</a>,该教程介绍了如何使用 NetBeans IDE 中的高级导航和编辑功能来查看和修改源代码。
</p>
<p>有关在 NetBeans IDE 中使用 C/C++/Fortran 进行开发的更多文章,请参阅 <a href="https://netbeans.org/kb/trails/cnd.html">C/C++ 学习资源</a></p>
<div class="feedback-box"><a href="mailto:users@cnd.netbeans.org?subject=Feedback:%20C/C++%20Projects%20Quick%20Start%20-%20NetBeans%20IDE%207.4%20Tutorial">发送有关此教程的反馈意见</a></div>
</body>
</html>