vs2019怎么调试设置开始运行(不调试)?

在 VS2005 上编写、 运行、 C 语言程序 目录 湔言: 关于 C/C++编译器的简单介绍

本文将介绍在 VS2005 下怎么开发 C 语言程序1. 编辑、 编译与运行以下以建立一个判断能否是闰年的程序来演示怎样使鼡 VS2005 开发 C 程序。 1. 启动 VS2005 新建一个项目, 新建方式有下列几种: A: 在 VS2005 默认的“起始页” 有构建项目一项 “项目(P)” 即可, 如图 1 B: 文件 -> 新建-> 项目 或者使用快捷键“Ctrl+shift+N”2. 由方法 1 可以得到下面窗口, 在项目类别中选取 Visual C++ 在右边模板中右键“Win32 控制台应用程序”, 然后在“输入名称” 提示处写项目名称 如图 3-1 所示: 如: LeapYear, 名称下方的“位置” 可以单击“浏览” 按钮来设置 然后点击“确定” 或者“回车鍵” 即可。然后出现“欢迎使用 Win32 应用程序向导” 对话框 单击“下一步”。

如图 3-2 示: 单击“下一步” 出现下面对话框 选择“空项目”, 单击“完成” 如图 3-3 所示:3. 在窗口的右侧默认出现“解决方案资源管理器, 解决方案 LeapYear” 一栏 下面列举LeapYear, 并包含头文件和源文件及資源文件三个文件夹 如图 4 所示 4. 新建一个 C 文件: 如图 5 所示: 在“源文件” 上单击右键, 在出现的“添加” 栏目上点击“新建项” <这里吔可以添加现有项, 即将要用别的编辑器写好的 C 代码源程序可以通过此选项添加到 LeapYear 解决方案来> 这里引入“新建项”。4. 单击“新建项” 出现如下的对话框, 在上面“类别” 一栏选取“代码” 右侧的“模板”中选取“C++文件”, 在上面名称一栏输入:“/a/jisuanjixue/article-.html

微软正式发布了新一代的集成开發环境Visual Studio 2019该版本可以让开发者更好的进行开发工作,并且 Visual Studio 2019 将能与 VS2017 一起运行而不需要将操作系统升级到主要版本。新云网为大家分享VS2019社区蝂下载需要的朋友不要错过了。

在VS2019版本中有一些关键更改从一个新的启动窗口开始,该窗口旨在更好地与GitHub、Azure Repos等在线存储库配合使用伱仍然可以打开或创建新项目,因此不必担心这一点VS2019 UI中的其他变化包括全新的蓝色主题,以及更紧凑的标题和菜单栏微软表示,它正茬努力优化菜单栏

Visual Studio 2019中增加了新的搜索体验,它取代了以前版本中的“快速启动”框搜索框允许你查找设置、命令和***选项,它还支歭模糊搜索因此即使拼错单词,你也可以找到所需的结果

Visual Studio 2019还为开发本身带来了不少改进。代码重构得到改进以保持代码清洁和易于維护性。还有文档运行状况指示器和清理选项帮助用户更容易识别代码问题。IntelliCode(智能代码辅助开发)也进行了改进可以自动完成建议哽具有上下文感知能力,不仅与使用中的API有关而且与项目中的其余代码有关。

微软还将Visual Studio Live Share直接集成到Visual Studio 2019中该功能于去年年底推出,允许多囚实时在同一项目代码上协同工作通过集成,还可以更轻松地启动Live Share会话以及管理与你合作的人员任何项目、应用类型和语言也将启用Live Share支持。

最后微软正在为pull request引入一种新体验,允许你从VS2019中查看、运行和调试它们目前,该功能支持Azure Repos但将来会添加对GitHub的支持。

Visual Studio 2019也将是第一個支持使用NET Core 3构建任何平台应用的应用程序,但该团队承诺将继续改进跨平台C++的开发

效率更高现在,Visual Studio现在将在后台下载更新

创建新项目的改进基于标签的搜索和轻松访问"最近的项目模板"列表中。

创建新项直接从Visual Studio搜索并更快地找到与改进的关联性

体验改进按监视器感知(PMA)支持通过具有完整PMA功能和许多可用性问题的修补程序的多个组件。

了解的重要信息例如Visual Studio实时共享请求,有一个新通知体验

将一系列代码清理fixers保存为能够轻松选择所需代码清理期间运行的fixers的配置文件。

新的触发器NET重构和代码修补程序。

请参阅与预览、付费和试用版Φ的标记扩展的状态扩展和更新对话框

检查并配置哪些预览功能所需active由于已在此预览版中重置默认值。

通过排除某些使扩展保持最新测試窗口已标记为在此版本中弃用的Api

我们已从服务器资源管理器;删除与Azure应用服务相关的功能而是在云资源管理器提供了等效功能。

了解新赽捷方式生成所选内容和快速生成全部中与新的CMake生成所有命令

加载项目依赖项快速使用新的项目上下文菜单命令。

请参阅中的性能提示嘚性能中心

使用突出显示热路径性能Profiler中的CPU和DotNet对象分配工具。

体验在编辑器中的代码分析警告代码分析自动在后台和警告显示为绿色波浪线。

尝试使用全新模板栏使用在查看窗口UI,并支持嵌套模板

运行新的、已更新的c + +实现生存期配置文件检查器。

预览版F# 4.6除了细微改进F#編译器和工具

调试单元测试Node.js项目中。

遇到的构建从TypeScript项目的用户的其他支持NuGet和npm包

更轻松地使用Python环境,包括改进了对使用新的Python环境选择器笁具栏的打开文件夹支持

体验的增强功能Azure DevOps工作项体验包括内联分配工作项和改进的#mentions体验的支持。

使用项目文件更轻松地探索和体验的更恏的控制台应用NET Core工具。

体验增强功能摘要的所有应用的发布配置文件此外,一个名为的新部分依赖项现已推出应用程序发布到Azure应用服務时

体验更流畅地单个项目用于容器化和调试。

请使用添加了对调试Alpine和其他基本映像

使用Xamarin进行移动开发

加快生成时间与我们改进生成茬Xamarin.Android中。

尝试使用Xamarin.Android设计器改进初始支持约束布局

轻松设置和编辑与新的属性面板的Xamarin.Forms控件属性。

使用Xamarin.Forms预览程序而无需生成应用程序

体验稳萣性/性能的更新。

查看更多详细的生成进度信息

提高性能时创建新的Xamarin项目。

    一个变量未初化、未赋值就读取它的值。 
    ( 这属于逻辑问题往往是粗心大意的导致的 ) (1)定义了一个体积太大的局部变量 
    (2)函数嵌套调用,层次过深(如无穷递歸) 访问数组元素时下标越界

在软件开发周期中,测试和修正缺陷(defectdefect与bug的区别:Bug是缺陷的一种表现形式,而一个缺陷是可以引起多种Bug嘚)的时间远多于写代码的时间通常,debug是指发现缺陷并改正的过程修正缺陷紧随debug之后,或者说二者是相关的如果代码中存在缺陷,峩们首先要识别造成缺陷的根本原因(root cause)这个过程就称作调试(debugging)。找到根本原因后就可以修正缺陷。

那么如何调试代码呢Visual Studio提供了佷多用于调试的工具。有时调试需要花费大量时间去识别root causeVS提供了许多辅助调试的便捷的工具。调试器(Debugger)包含错误列表、添加断点、可視化的程序流程、控制执行流程、Data Tips、监视窗口(watch

可以通过VS的调试(Debug)菜单启动调试点击调试菜单下的“启动调试”或者按F5键启动。如果伱已经在代码中加入了断点那么执行会自动开始。

“附加到进程(Attach to Process)”是另一种启动调试的方法Attach Process会为应用程序启动一个调试会话。可能我们更熟悉ASP.NET Web应用的Attach Process调试我发了另外两篇相关的帖子。如下:



通常我们通过在可能存在问题代码处加断点来启动调试因此,我们从断點开始讲起

断点用于通知调试器何时何处暂停程序的执行。通过点击左边栏或者按F9键在当前行添加断点在加断点之前,你需要知道你嘚代码将会出现什么错误在什么地方停止执行。当调试器执行到断点处时你可以使用其他的调试工具核对代码何处出现错误。

3.1 使用断點进行调试

你已经在你想要暂停执行的地方设置了断点现在按F5键启动调试,当程序执行到断点处时自动暂停执行。此时你有多种方式來检查代码命中断点(hit the breakpoint)后,加断点的行变为***意指下一步将执行此行。

在中断模式下你有多条可使用的命令,使用相应命令进荇进一步的调试

调试器执行到断点后,你可能需要一条一条的执行代码”Step Over“[F10]命令用于一条一条的执行代码。这将执行当前高亮的行嘫后暂停。如果在一条方法调用语句高亮时按F10执行会停在调用语句的下一条语句上。Step Over会一次整个方法

它与Step Over相似。唯一的不同是如果當前高亮语句是方法调用,调试器会进入方法内部快捷键是”F11“

当你在一个方法内部调试时会用到它如果你在当前方法内按Shift - F11,调试器会完成此方法的执行之后在调用此方法的语句的下一条语句处暂停。

它像是重新执行你的程序它会继续程序的执行直到遇到下一个斷点。快捷键是”F5“

这是一个非常有趣的特性。设置下一语句允许你在调试的时候改变程序的执行路径如果你的程序在某一行处暂停洏且你想改变执行路径,跳到指定行在这一行上右击,在右击菜单中选择”设置下一语句“这样程序就会转到哪一行执行而不执行先湔的代码。这在如下情况中非常有用:当你发现代码中某些行可能会导致程序的中断(break)而你不想让程序在那个时候中断快捷键是Ctrl

这一荇用***箭头标记。这行是程序继续执行时下一条将执行的语句

这是VS2010提供的新特征(feature)。用于更好的管理断点它使得我们能够更好的汾组和过滤断点。这像是对断点的归类如果我们添加了与某一功能相关的不同类型的断点,我们可以根据需要使能(enable)、取消(disable)、过濾(filter)这些断点例如,假设我们要调试一下代码块

执行程序将停在第一个断点处。下图给出了断点列表

上图中Labels列都为空。下面介绍洳何给断点设置标签(label)以及如何使用标签只需在特定代码行的断点符号上右击(①)或者在断点窗口中设置(②)即可对任何断点设置标签。

右击断点点击编辑标签(Edit Labels),即可对任意断点添加标签对于示例代码,我为所有断点的标签起了易于理解的名字

这些标签洳何辅助我们调试呢?现在所有断点都是使能的(enabled)。如果你不想调试method2一般情况下你必须去对应的方法中一个一个的取消断点,但这裏你可以通过标签名过滤或者搜索它们然后选中它们以方便的取消它们。

断点标签到此介绍完毕我举的例子非常简单,但是断点标签茬你调试大量代码多个工程等情况下非常有用。

假设你在多次迭代(循环)处理数据而你只想调试其中某几次迭代这意味着你想根据某些特定条件暂停你的程序。Visual Studio断点允许你设置条件断点当且仅当条件满足时,调试器才会停住

首先,你需要在你想暂停执行处设置断點然后右击红色的断点图标。右键菜单中点击”条件“

点击右键菜单中的”条件“后,会弹出下面的对话框设置断点的条件

假设你偠调试下面的代码块:

查看断点符号。它应该看上去像是一个加(+)号在断点符号内部这表示该断点是条件断点。

设置断点的条件之后在调试程序,调试器只会在满足给定条件时才停住

条件输入框的自动补全(intellisense):上面给出的断点条件非常简单,可以非常容易的写到條件文本框中有时你可能需要定义很大很复杂的条件。不必担心VS为条件文本输入框也提供了自动补全功能。因此在条件框中输入就潒是在编辑器中一样方便。如下图

我几乎讲解了条件断点的所有内容。除了下面这点在条件窗口中有两个选项:

我们已经看到”Is True“选項的用途了。”Has Changed“用在当你想在某些值变为某些特定值的时候停住

你可以限制断点只对特定进程或线程有效。这在进行多线程程序的调試时非常有用右击断点选”筛选器“即可打开筛选器窗口。

在筛选规则中你可以设置进程名,进程Id机器名,线程ID等我会在多线程調试小节中详述其用法。

数据便签是应用程序调试期间用于查看对象和变量的一种高级便签消息当调试器执行到断点时,将鼠标移到对潒或者变量上方时你会看到它们的当前值。你甚至可以看到一些复杂对象(如datasetdatatable等等)的细节。数据便签左上角有一个“+”号用于展开咜的子对象或者值

下面是一些在调试时有用的特性。

列出当前方法中的所有变量当调试器停在某特定断点并打开Autos窗口时,将展示当前范围中与此值相关的变量

这些变量由VS调试器在调试的时候自动检测。VS检测与当前语句相关的对象或变量基于此列出Autos变量。Autos Variable的快捷键是Ctrl + D + A

Watch窗口用于添加变量。你可以添加任意多个变量添加方法是,右击变量并选择“Add to Watch”

也可以使用拖放(Drag and Drop)将变量添加到监视窗口中。从監视窗口中删除变量的方法是右击变量并选择“Delete Watch”。通过调试窗口也可以在运行时编辑这些变量值。

有4个可同时使用的监视窗口

若果变量中含有对象实例,左边会有一个“+”号用于查看对象的属性和成员

Visual Studio调试器提供另外一个强大的功能,支持我们为对象的任何一个特定实例创建一个对象ID(object ID)这可以用于在任何时间监控任意对象,甚至是该对象位于范围(scope)之外在监视窗口(watch window)右击特定对象变量,再单击“Make Object ID”即可创建Object ID

在对特定对象变量创建Object ID之后,Visual Studio会给这个对象添加一个数码和“#”号用来表示。

即时窗口是开发人员常用的功能它可以在不改变当前调试步骤的情况下修改变量值或者执行一些语句。我们可以通过菜单调试 > 窗口 > 即时(Debug > Window > Immediate Window)打开即时窗口即时窗口支歭一组命令,可在调试的任何时刻执行它也支持Intellisense。在调试期间我们可以在即时窗口中执行任何命令或者代码语句。

这是对所有开发人員来说最为常用的特性因此我就不一一介绍即时窗口的每一条命令了。

到此本文结束希望你喜欢本文。请分享你的反馈和建议

本文介绍了调试过程的基本内容。介绍了如何使用VS调试一个应用程序我解释了几乎所有重要的工具以及它们的使用方法。对于并行程序调试我只讲了基础部分。在深入学习小节中深入讲解了并行调试过程。如果你感兴趣请阅读。我的主要目的是涵盖Visual Studio中提供的几乎所有调試工具希望你从本文中学到了一些新知识。

“自动窗口”(Autos):当前使用的变量

“局部窗口”(Locals):在范围内的所有变量

“监视N”(Watch):可定制(N从1到4)

Step Into(逐语句):执行并移动到下一条语句(实际上跳入上一条语句的代码块,此代码块的第一条)

Step Over(逐过程):执行并跳到下一条语句但不进入上一条语句的代码块

Step Out(跳出):执行到代码块结尾

即时窗口(Immediate):主要用于计算表达式


设置断点:在如下图中的红色圆點处设置断点红色圆点表示已经在这行设置断点。快捷键F9

启动调试:按F5或者点击左边红框中的按钮。右边框是开始执行(不调试)Ctrl+F5

调试笁具栏:下面是工具栏中对应的名称和快捷键。

在调试过程中F5是执行到下一个断点F11是逐语句,在执行到下图中的断点时按F11会执行到Fibonacci方法里面逐步记录执行过程。F10是逐过程与逐语句不同的是,在执行到下图中断点时再执行会执行断点下面的语句,而不是去执行语句中嘚方法

局部变量:在调试过程中可以查看局部变量窗口,如下图里面会有变量的当前状态如果找不到的话在

数组的状态表示如下图:

開发人员设置断点,运行程序利用不同的输入触发断点,然后在断点处手工检查是否满足某些特定的条件从而决定是否继续调查。如果当前场景不是他们想要的按F5继续运行程序,尝试别的输入手动重复刚才的过程。

针对上述情况Visual Studio提供了一个方便得多的功能——“條件中断”。只有当程序满足了开发人员预设的条件后条件断点才会被触发,调试器中断这将避免频繁地手工检查/恢复程序运行,大量减少调试过程中的手工和烦琐工作

设置条件断点非常容易。在特定的行上按F9设置断点。

然后右击断点–编辑窗口左侧的红点在上丅文菜单上选择“条件”。

这时弹出一个对话框供你设置激活该断点所需的条件比如:我们希望只有当x==5时,调试才中断我们可以写出洳下的表达式:

现在我再运行这个程序按F5达到条件断点,只有当x等于5时程序运行才会被中断。对于其它条件下的x值断点将被跳过。

有時你希望只有当第N次满足条件的运行到达断点时,才中断程序运行例如:当第一次命中断点。可以通过右击断点然后在弹出菜单上選择“命中次数”菜单命令实现。

这时系统弹出一个对话框它允许你指定:(1)当满足条件,而且进入断点的累计次数等于N时断点命Φ一次。(2)当满足条件而且进入断点的累计次数是N的倍数时,断点命中一次(3)当满足条件,而且进入断点的累计次数大于N时每佽命中断点。

注意:如果多个条件同时用的话结果取交集。

例如在调试一个服务程序时在其内部打上了断点,由于这是一个公用的服務不希望其他访问这个服务的程序被所设断点调试干扰怎么办?断点筛选器就是限制只在某些进程和线程中设置断点筛选器文本框中輸入以下一个或多个子句,可以使用&(AND)、||(OR)、!(NOT)和圆括号组合这些子句描述应在何处设置断点的表达式或者清除该表达式以便在所有进程和线程中设置断点。比如希望断点只在被机器名为xye-PC的机器访问时才触发,我们可以右击断点进行断点筛选器设置当其他机器访问程序的时候断点不会触发,其他机器访问时感觉不到断点的存在

跟踪点进入断点时的自定义操作

许多人不知道“跟踪点(TrackPoints)”这个调试功能。“跟蹤点“是种特殊的断点当它被命中时,它会触发一系列自定义操作如果你想观察程序的行为,而又不想中断调试的时候这个功能尤其有用。

我将用一个简单的控制台程序来演示如何使用“跟踪点”如下是斐波那契数列的一个递归实现:

以上程序中,我们使用Console.WriteLine() 输出针對特定输入值生成的最终斐波那契数列如果希望在调试器里观察操作中每一次递归运算后的数列而又不实际中断程序运行,该怎么办呢“跟踪点”可以轻松实现。

你可以在特定的行上按F9加跟踪点。然后右击断点在上下文菜单中选择“命中条件”:

在弹出对话框上,伱可以设置命中该断点时所触发的事件。

在上面例子中我们设定一旦命中断点时就打印追踪信息。注意我们已经把局部变量“x”的徝,作为追踪信息的一部分输出局部变量可以通过{变 量名}语法输出。你还可以利用系统内置的命令($CALLER, $CALLSTACK, $FUNCTION等等)在追踪信息中输出常用的調试值。

在上例中我们同时选中了底端的“continue execution“选项,这说明我们不希望程序中断调试状态而是继续运行。唯一的不同是:每次断点条件满足时我们的自定义追踪信息都将被输出。

现在当我们运行程序时会发现自定义追踪信息自动显示在Visual Studio的“输出“窗口里。这让我们佷容易看到程序的递归调用过程:

你也可以选择往应用程序中添加一个自定义追踪信息的***器这时追踪点的输出信息将通过它输出,洏不是Visual Studio的“输出“窗口

参考资料

 

随机推荐