#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
调试的基本步骤
1.发现程序错误的存在
2.以隔离,消除等方式对错误进行定位
3.确定错误产生的原因
4.提出纠正错误的解决办法
5.对程序错误予以改正,重新测试
debug是调试版本,release是发布版本
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;
}
for (i = 0;i < sz;i++) //设置断点,按f5调试前面的就跳过了
{ //右击断点,按条件,可以之间跳条件
printf("%d\n", arr[i]);
}
return 0;
}
void test2() //调用堆栈反应的是函数的调用逻辑
{
printf("hehe\n");
}
void test1()
{
test2();
}
void test()
{
test1();
}
int main()
{
test();
return 0;
}
一些调试实例:
int main()
{
int n = 0;
scanf("%d", &n); //3
//1! + 2! + 3!
//1 + 2 + 6=9
int i = 0;
int ret = 1;
int sum = 0;
int j = 0;
for (j = 1;j <= n;j++)
{
//ret = 1;
for (i = 1;i <= j;i++) //调试结果是ret没有初始化
{
ret *= i;
}
sum += ret;
}
printf("%d\n", sum);
return 0;
}
实例2
int main()
{
int i = 0;
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
for (i = 0;i <= 12;i++)
{
arr[i] = 0; //越界访问
printf("hehe\n");
}
return 0;
}
代码运行的结果是什么? - 死循环 - i 和 arr[12]地址相同
1. i 和 arr是局部变量 - 局部变量是放在栈区上的
栈区内存的习惯是:先使用高地址空间,再使用低地址空间
2. 数组随着下标的增长地址,是由低到高变化的
模拟实现库函数strcpy - strcpy字符串拷贝
#include <string.h>
还需要优化,效果不是特别好,具体看下一个
void my_strcpy(char* dest, char* src)
{
while (*src != '\0')
{
*dest = *src;
dest++;
src++;
}
*dest = *src;
}
void my_strcpy(char* dest, char* src)
{
while (*dest++ = *src++) //即copy了\0,又使得循环停止
{
}
}
int main()
{
char arr1[20] = "xxxxxxxxxxx";
char arr2[] = "hello";
my_strcpy(arr1, arr2);
//strcpy(arr1,arr2);
printf("%s\n", arr1);
return 0;
}