调试技巧 (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. 数组随着下标的增长地址
是由低到高变化的
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律