• Visual Studio的调试bug


    一、调试的基本步骤

    • 发现程序错误的存在
    • 以隔离、消除等方式对错误进行定位
    • 确定错误产生的原因
    • 提出纠正错误的解决办法
    • 对程序错误予以改正,重新测试

    二、 Debug和Release的介绍。

    Debug 通常称为调试版本,它包含调试信息,并且不作任何优化,便于程序员调试程序。
    Release 称为发布版本,它往往是进行了各种优化,使得程序在代码大小和运行速度上都是最优
    的,以便用户很好地使用。

    三、调试环境的准备

    在环境中选择debug 选项,才能使代码正常调试。
    在这里插入图片描述

    常使用的几个快捷键

    注意有可能电脑设计的是组合键,那么要加上Fn

    • F5
      启动调试,经常用来直接跳到下一个断点处。
    • F9
      创建断点和取消断点
      断点的重要作用,可以在程序的任意位置设置断点。
      这样就可以使得程序在想要的位置随意停止执行,继而一步步执行下去。
    • F10
      逐过程,通常用来处理一个过程,一个过程可以是一次函数调用,或是一条语句
    • F11
      逐语句,就是每次都执行一条语句,但是这个快捷键可以使我们的执行逻辑进入函数内部(这是最常用的)。
    • CTRL + F5
      开始执行不调试,如果你想让程序直接运行起来而不调试就可以直接使用。

    3.3 调试的时候查看程序当前信息
    3.3.1 查看临时变量的值
    在调试开始之后,用于观察变量的值。比特就业课比特就业课-专注IT大学生就业的精品课程比特主页:https://m.cctalk.com/inst/s9yewhfr

    四、调试

    查看临时变量的值

    调试开始之后,用于观察变量的值。如果不调试的话,就不能去查找监视器。
    在这里插入图片描述
    在这里插入图片描述

    查看内存信息

    在这里插入图片描述

    查看汇编信息

    在这里插入图片描述

    五、 编程常见的错误

    5.1 编译型错误
    直接看错误提示信息(双击),解决问题。或者凭借经验就可以搞定。
    5.2链接型错误
    看错误提示信息,主要在代码中找到错误信息中的标识符,然后定位问题所在。一般是标识符名不存在或者拼写错误。
    5.3 运行时错误
    借助调试,逐步定位问题。最难搞。

    六、实例

    实现代码:求1!+2!+3! …+ n! ;不考虑溢出

    int main()
    {
    	int i = 0;
    	int sum = 0;//保存最终结果
    	int n = 0;
    	int ret = 1;//保存n的阶乘
    	scanf("%d", &n);
    	for (i = 1; i <= n; i++)
    	{
    		int j = 0;
    		for (j = 1; j <= i; j++)
    		{
    			ret *= j;
    		}
    		sum += ret;
    	}
    	printf("%d\n", sum);
    	system("pause");
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    这时候我们如果3,期待输出9,但实际输出的是15。
    这里我们就得找我们问题,设ni3,那么执行三次:

    第一次:
    在这里插入图片描述
    第二次
    在这里插入图片描述
    第三次:
    在这里插入图片描述

    原因就是ret是保存n的阶乘,但是第二次的时候初始值不是1而是2。
    修改:第一个循环是计算n个数,第二个循环是计算那个数的阶乘,ret是保存n的阶乘,因此在内循环之前要将ret置为1,而不是在最外层。

    int main()
    {
    	int i = 0;
    	int sum = 0;//保存最终结果
    	int n = 3;
    	//int ret = 1;//保存n的阶乘
    	scanf("%d", &n);
    	for (i = 1; i <= n; i++)
    	{
    		int j = 0;
    		int ret = 1;//保存n的阶乘
    		for (j = 1; j <= i; j++)
    		{
    			ret *= j;
    		}
    		sum += ret;
    	}
    	printf("%d\n", sum);
    	system("pause");
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
  • 相关阅读:
    使用docker搭建kafka集群、可视化操作台
    spark sql重分区
    STP切换测试_组网实验
    DevOps|1024程序员节怎么做?介绍下我的思路
    初级爬虫的总结一
    LogBack
    Turtlebot4入门教程-产品特征
    基于51单片机的可调节占空比四种三种波形发生器proteus仿真
    java中流的分类
    工作22年后明白的22条职场道理
  • 原文地址:https://blog.csdn.net/qq_40599849/article/details/126136672