目录
三、“SEGV” 与 “load of null pointer”
前言
你是否会在写完一整串代码之后提交,发现leetcode报错了一大堆看不懂的英文呢?最后在代码中找大半天bug,学会总结会让你少走很多弯路!
对照你的报错信息,在简单的例子中找出你的错误吧。
一、stack-overflow
栈溢出:
1.while、for死循环
① 在循环体中更改了循环变量(i)的值,导致循环无法正常结束
② 循环条件错误
int i = 0;
while (i = 0) { //你可能想的是当i等于10时进入循环
printf("%d", i);
i++;
}
上述例子中你可能想要的判断条件为 i == 0,但是写成了将0赋值给了i,赋值表达式的返回值为true,所以while会死循环,看似很弱智的错误,在写代码的过程中有时一分心就写错了。
2.无限递归导致栈溢出
二、heap-buffer-overflow
堆缓冲区溢出:
1. 数组越界访问
你可能也会在做题中经常遇到这样的一大串报错,是因为你没有很好的防越界的意识!双指针、动态规划、回溯等题中
当你在循环中用一个变量指向数组的一个位置时,你应对该变量的返回设置范围限制;
eg.
while (i < arrSize && arr[i] == 0) {
;
}
2. 字符串无结束标志 ‘ ‘
或许你想malloc一个动态内存存储字符串,但是字符串需要一个结束标志 ‘ ‘ ,表示字符串的读取结束,解决方法很简单:
char* str = (char*)malloc(sizeof(char) * (strSize + 1));
//.
//操作str
//.
str[strSize] = '';
或者你可以用calloc开辟空间,在之前文章讲解过,calloc开辟空间后对对其初始化为0,而 ‘ ‘的ASCII值就是0,所以自然就可以解决上述问题了
char* str = (char*)calloc((strSize+1),sizeof(char);
//.
//操作str
//.
三、“SEGV” 与 “load of null pointer”
1. 二维数组传参
这个问题实在我做深搜的题时遇见的,二维函数传参类型并不是 int **, 所以不能用二级指针接收,目前我认为最好的解决方法就是用二维数组接收
int Row;
int Col;
void test(int arr[Row][Col]) {
}
int main() {
Row = 5;
Col = 5;
int used[Row][Col];
memset(used, 0, sizeof(used));
test(used);
return 0;
}
四、其他
1. 返回值使用错误
具体案例:
int** res = (int**)malloc(sizeof(int*)*peopleSize);
*returnSize = 0;
for (struct listNode* p = phead->next; p != NULL; p = p->next) {
res[*returnSize++] = p->people;
/*正确写法:
res[(*returnSize)++] = p->people;*/
}
*returnColumnSizes = peopleColSize;
return res;
To be continued
原文地址:https://blog.csdn.net/Dusong_/article/details/128895586
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_51375.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!