调试技巧 (2)

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>

//void test2()
//{
//	printf("haha\n");
//}
//void test1()
//{
//	test2();
//}
//void test()
//{
//	test1();
//}
//int main()
//{
//	test();
//	return 0;
//}	  
main-->test-->test1-->return test2-->return test1-->return test-->return main
压栈

多多动手,尝试调试,才能有进步
//int main()
//{
//	int arr[10] = { 0 };
//	int sz = sizeof(arr) / sizeof(arr[0]);
//
//	int i = 0;
//	for (i = 0; i < sz; i++)//当循环次数很大时,可以设置条件断点,右击断点设置条件
//	{
//		arr[i] = i + 1;
//		printf("%d ", arr[i]);
//	}
//	return 0;
//}

//运行时错误!
//调试解决的是运行错误
//解决问题:
//应该是什么结果-预期
//调试的时候发现不符合预期就找到问题了

//1+1!+2!+3!+...不考虑溢出
//int main()
//{
//	int n = 0;
//	scanf("%d", &n);
//
//	int i = 0;
//	int ret = 1;
//	int sum = 0;
//	int j = 0;
//	for (j = 1; j <=n; j++)
//	{
//		//经过调试发现每一个i的循环结束,ret的值不会重置
//		//ret=1,1*2=2,2*1*2*3=12
//		//1+2+12=15
//		for (i = 1; i <= j; i++)
//		{
//			ret *= i;
//		}
//		sum += ret;
//	}
//	printf("%d\n", sum);
//	return 0;
//}

//int main()
//{
//	int n = 0;
//	scanf("%d", &n);
//	int ret = 1;
//	int i = 0;
//	
//	int sum = 0;
//	int j = 0;
//	for (j = 1; j <= n; j++)
//	{
//		ret = 1;
//		for (i = 1; i <= j; i++)
//		{
//			ret *= i;
//		}
//		sum += ret;
//	}
//	printf("%d\n", sum);
//	return 0;
//}

//int main()
//{
//	//先定义i,再定义arr
//	int i = 0;
//	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
//	//0-9
//	for (i = 0; i <= 12; i++)
//	{
//		arr[i] = 0;
//		printf("hehe\n");
//		
//	}
//	//代码运行的结果是什么?代码死循环
//	return 0;
//}

//int main()
//{
//	//先定义数组,再定义i,非法访问就会报错
//	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
//	int i = 0;
//	for (i = 0; i <= 12; i++)
//	{
//		arr[i] = 0;
//		printf("hehe\n");
//	}
//	return 0;
//}

内存分布图像

1. i 和 arr 是局部变量
局部变量是放在栈区上的
栈区内存的使用习惯是:先使用高地址空间,再使用低地址空间
2. 数组随着下标的增长地址
是由低到高变化的

posted @   morphism  阅读(11)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示